- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试清理我的脚本,这样我就不必每次使用它时都更改变量。
我有美国每个州(加上华盛顿特区和波多黎各)的 arcgis 表。我想迭代文件夹中的这些表,一次将每个表连接到一个 shapefile,将连接的要素复制到不同地理数据库中的新要素类,在相应的州名称之后命名该要素类,然后删除联接并继续到下一个状态。
当谈到Python时,我认为自己是一个新手。多年来我一直在尝试自学,但一直没有很好的机会参加深入的类(class),而且与我一起工作的人也没有对此非常了解。我知道有更有效的脚本编写方法,例如循环、函数和条件语句,但我不知道如何正确设置它们。
因此,我创建了一个脚本来完成我今天需要完成的工作,但我想让该脚本更加动态。我不想更改每个表名称或新要素类名称。我试图查找如何为部分代码创建自定义函数,但同时也有一个循环,以便它知道迭代文件夹中的每个表。我不确定是否需要先有循环,然后是函数,或者在函数内部有循环。然后我不确定如何获取输出要素类的正确名称,我知道有一种方法可以用 %s 引用动态变量,但不确定如何将其合并到这里。
layer = arcpy.GetParameterAsText(0)
inField = "GEOID"
jTable = r'k:\geospatial\data\census\national\census_fact_finder_data\census_tract_year_built\aa_by_state\xls_pcts\tables'
jField = "GEOID"
outFC = r'K:\GEOSPATIAL\DATA\Census\National\Census_Fact_Finder_Data\Shapefiles\CFF_Census_Tracts\PCTs\FCC_CT_YB_PCT.gdb'
arcpy.AddMessage("Processing Arizona...")
#join table to census tract layer
arcpy.AddMessage("Joining Arizona table to Census Tracts...")
tract_join = arcpy.AddJoin_management(layer, inField,jTable + "\\az_pcts", jField, "KEEP_COMMON")
#Copy joined features to new feature class in geodatabase
arcpy.AddMessage("Exporting joined features to FCC_CT_YB_PCT geodatabase...")
arcpy.CopyFeatures_management(tract_join, outFC + "\Arizona_PCT")
#remove all joins
arcpy.AddMessage("Removing joins to process next table...")
arcpy.RemoveJoin_management(layer)
arcpy.AddMessage("Arizona Complete")
因此,在上面的示例中,它将亚利桑那州表 (az_pcts
) 连接到人口普查区图层 (layer = arcpy.GetParameterAsText(0)
),复制连接的数据添加到新数据库的功能并将其命名为 Arizona_PCT
,然后删除连接并继续处理下一个表。我为每个状态表重复了同样的结构,并将所有路径结尾更改为我想要的内容。如果有人有任何建议,甚至是片段,我们将不胜感激。
最佳答案
首先,欢迎来到 Stack Overflow。您可以使用模型构建器完成所有这些操作。看: What is model builder and quick tutorial
但是我不明白你在文件夹中找到了什么样的表?通常,您需要在文件地理数据库、个人地理数据库或 RDBMS 表中指定文件夹,而不是文件夹。但我跳过了这个问题,并在上面为您提供了示例代码。
无论如何,我为你准备了一些代码。您可以关注:
import arcpy
# iterating all tables in an environment , and make join them with a shapefile
# these are constant variables
shapefilepath = r"c:\users\someplace\someshape.shp"
commoncolumn = "SAMECOLUMN" # this column must be same in other shapefiles too
# If all shapefile samecolumns are different each other, you need to make a list like this
commoncolumns_ordered = ['SAMECOLUMN1', 'SAMECOLUMN2', ] # .. goes away
mainfolder = r"c:\users\someplace"
tablegdb = r"c:\users\someplace\somegdb.gdb" # we'll search our tables here
arcpy.env.workspace = tablegdb # we will work on here
mytables = arcpy.ListTables("*") # you can filter your tables as starting or ending with a letter.
for table in mytables:
# you need to make view from all tables
name = arcpy.Describe(table).name.encode('utf-8') # my table name
table_view = arcpy.MakeTableView_management(table, name)
# ok so we have our view. Otherwise, we would not be able to use this as an input for add join tool
"""
There are couple differences between add join and join field tools. Read them:
Add join help : https://pro.arcgis.com/en/pro-app/tool-reference/data-management/add-join.htm
Join field help : https://pro.arcgis.com/en/pro-app/tool-reference/data-management/join-field.htm
* We don't have to make table view if we use join field
"""
# i assume that both common columns, # fields are same.
out_join = arcpy.AddJoin_management(table_view, commoncolumn, shapefilepath, commoncolumn)
# extracting them is not useful. But I'll write it down:
arcpy.Copy_management(out_join, out_data="%s\\%s" % (out_gdb, name))
# some notes:
# If your samecolumn fields are different between each other in tables
# you need to iterate them like this:
for table, column in zip(mytables, commoncolumns_ordered):
print (table)
print (column)
# do others
关于python - Arcpy 脚本循环 - 如何循环遍历文件夹中的表并对每个表执行 arcpy join 函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55504614/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!