如何使用arcpy批量将字段名从大写转换为小写

import arcpy
#Set workspace
arcpy.env.workspace = r'E:\testpy\examples\symbology\ToolData\Input.gdb\PlanA_Roads'
fc = r'E:\testpy\examples\symbology\ToolData\Input.gdb\PlanA_Roads11'
fieldList = arcpy.ListFields(fc)  #get a list of fields for each feature class
for field in fieldList[2:]: #loop through each field
     print  field.name
     arcpy.AlterField_management(fc, field.name, field.name.lower()+"zz")
    #arcpy.AlterField_management(fc, field.name, field.name[:-2])

fieldList[2:]这个地方需要注意,字段前两个是OBJECTID和Shape,无需转换。

这段代码是绕了一个弯实现的。

field.name.lower()不能实现直接转换,需要再其后边加上字符,如+“zz”;之后,再使用field.name[:-2]将“zz”字符去除。

可能是arcmap的bug,需要后续确认。
使用arcpy批量添加字段的方法如下: 首先,使用arcpy.ListFeatureClasses()函数获取要添加字段的矢量文件列表。 然后,使用for循环遍历每个文件,使用arcpy.AddField_management()函数为每个文件添加一个名称为name的字段。 在arcpy.AddField_management()函数,将字段类型设置为"TEXT",字段长度设置为50。 最后,使用arcpy.CalculateField_management()函数为每个字段赋值为文件名称。 以下是示例代码: ``` import arcpy arcpy.env.workspace = r"E:\GEDIshuiku\shp" ListGEDI = arcpy.ListFeatureClasses() for i in ListGEDI: arcpy.AddField_management(i, "name", "TEXT", field_length=50) arcpy.CalculateField_management(i, field="name", expression=i\[9:22\], expression_type="VB", code_block="") ``` 这段代码会循环读取每一个矢量文件,给每一个文件添加一个名称为name的字段,并将字段赋值为文件名称的一部分。\[1\] #### 引用[.reference_title] - *1* [基于arcpy批量添加矢量属性表字段并赋值](https://blog.csdn.net/m0_46471094/article/details/127700032)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [arcpy——利用Arcpy进行字段操作](https://blog.csdn.net/knkn123/article/details/124278289)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值