GIS如何修改shp文件属性-源,的范围成xy坐标(如图二),而不是经纬度?我需要用字段几何计算器算两点的距离,有没有大佬?呜呜

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您好,可以使用下面的代码将txt文件转换为shp文件: ```python import arcpy # 设置工作环境和输出路径 arcpy.env.workspace = "C:/data" out_path = "C:/output" # 设置txt文件和输出shp文件名 txt_file = "data.txt" out_name = "data.shp" # 创建空的点层 sr = arcpy.SpatialReference(4326) # 设置坐标系 arcpy.CreateFeatureclass_management(out_path, out_name, "POINT", spatial_reference=sr) # 打开txt文件,并读取数据 with open(txt_file, "r") as f: # 跳过文件头,即第一行 next(f) # 读取每一行的数据,并将其转换为要素 for line in f: values = line.split(",") # 解析范围坐标 coord_str = values[3].strip() coords = coord_str.split(";") # 计中心点坐标 x = (float(coords[0]) + float(coords[2])) / 2 y = (float(coords[1]) + float(coords[3])) / 2 # 创建要素对象 point = arcpy.Point(x, y) feature = arcpy.Feature() feature.setGeometry(point) # 设置属性值 feature.set_value("编号", values[0].strip()) feature.set_value("名称", values[1].strip()) feature.set_value("类别", values[2].strip()) # 插入要素到层中 with arcpy.da.InsertCursor(out_name, ["SHAPE@", "编号", "名称", "类别"]) as cursor: cursor.insertRow([point, values[0].strip(), values[1].strip(), values[2].strip()]) print("转换完!") ``` 上述代码使用`arcpy`库创建了一个空的点层,并从txt文件中读取数据转换为要素插入到shp文件中。在运行前,需要将代码中的输入输出路径和文件名替换为实际的值。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值