我正在尝试从一个文件夹复制特定的文件到另一个文件夹。这些文件名在一个shapefile的属性表中。
我已经成功完成将文件名写入.csv文件并列出包含要传输文件名列表的列。但之后我无法读取这些文件名以将它们复制到另一个文件夹。我已经阅读了有关使用Shutil.copy/move的文章,但不确定如何使用它。任何帮助都将不胜感激。以下是我的脚本:
import arcpy
import csv
import os
import sys
import os.path
import shutil
from collections import defaultdict
fc = 'C:\\work_Data\\Export_Output.shp'
CSVFile = 'C:\\wokk_Data\\Export_Output.csv'
src = 'C:\\UC_Training_Areas'
dst = 'C:\\MOSAIC_Files'
fields = [f.name for f in arcpy.ListFields(fc)]
if f.type <> 'Geometry':
for i,f in enumerate(fields):
if f in (['FID', "Area", 'Category', 'SHAPE_Area']):
fields.remove (f)
with open(CSVFile, 'w') as f:
f.write(','.join(fields)+'\n')
with arcpy.da.SearchCursor(fc, fields) as cursor:
for row in cursor:
f.write(','.join([str(r) for r in row])+'\n')
f.close()
columns = defaultdict(list)
with open(CSVFile) as f:
reader = csv.DictReader(f)
for row in reader:
for (k,v) in row.items():
columns[k].append(v)
print(columns['label'])
with(open(filename, 'w') as f:....
时,您不需要使用f.close()
。当您退出with
块时,文件将自动关闭。最后,一个问题...在这个例子中,最后一行打印的文本print(columns['label'])
是您想要复制到目标目录的文件名吗?否则,我很好奇。 - OYRM