我一直在网上搜索,试图找到一种处理这些数据的pythonic(sp?!)方法。
每天我们都会收到大量 .dbf 格式的数据(希望如此)——然后我们需要将这些数据保存为 shapefile。
有人对我的流程有任何链接或任何建议吗?
要将文件的 creation_date 附加到其名称中,您需要使用 os.stat() 获取创建日期,然后使用os.rename()重命名文件。您可以使用date.strftime()格式化日期字符串。
import datetime, os
filename = 'original.ext'
fileinfo = os.stat(filename)
creation_date = datetime.date.fromtimestamp(fileinfo.st_ctime)
os.rename(filename, filename + '-' + creation_date.strftime('%Y-%m-%d'))
在我的头顶上:
import os
import datetime
myfile = "test.txt"
creationdate = os.stat(myfile).st_ctime
timestamp = datetime.datetime.fromtimestamp(creationdate)
datestr = datetime.datetime.strftime(timestamp, "%Y%m%d")
os.rename(myfile, os.path.splitext(myfile)[0] + datestr + os.path.splitext(myfile)[1])
重命名test.txt
为test20110221.txt
.
它一直在模型构建器中!
# (generated by ArcGIS/ModelBuilder)
# Usage: DBF2SHAPEFILE <XY_Table> <Y_Field> <X_Field> <Output_Feature_Class>
# ---------------------------------------------------------------------------
# Import system modules
import sys, string, os, arcgisscripting, datetime
# Adds the creation date to all of the previous shapefiles in that folder
filename = 'D:/test.txt'
fileinfo = os.stat(filename)
creation_date = datetime.date.fromtimestamp(fileinfo.st_ctime)
os.rename(filename, filename + '-' + creation_date.strftime('%Y-%m-%d'))
# Create the Geoprocessor object
gp = arcgisscripting.create()
# Load required toolboxes...
gp.AddToolbox("C:/Program Files/ArcGIS/ArcToolbox/Toolboxes/Data Management Tools.tbx")
# Script arguments...
XY_Table = sys.argv[1]
Y_Field = sys.argv[2]
X_Field = sys.argv[3]
Output_Feature_Class = sys.argv[4]
# Local variables...
Layer_Name_or_Table_View = ""
# Process: Make XY Event Layer...
gp.MakeXYEventLayer_management(XY_Table, X_Field, Y_Field, Layer_Name_or_Table_View, "")
# Process: Copy Features...
gp.CopyFeatures_management(Layer_Name_or_Table_View, Output_Feature_Class, "", "0", "0", "0")
如果您想在不使用 ArcGIS 的情况下执行此操作,则可以通过子进程使用OGR的 python 绑定或ogr2ogr 实用程序。您可以通过 Windows 批处理文件使用该实用程序,如果您有很多事情要做,这将比为每个文件调用 arc 进程要快得多......
如您所知,这不是更改扩展名的问题,而是需要特定的格式。