使用python将某些文件复制到另一个文件夹

时间:2015-04-27 01:13:59

标签: python file csv filenames

我正在尝试将某些文件从一个文件夹复制到另一个文件夹。文件名位于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'])

3 个答案:

答案 0 :(得分:2)

给出文件的名称 columns['label']您可以使用以下内容移动文件

srcpath = os.path.join(src, columns['label'])
dstpath = os.path.join(dst, columns['label'])
shutil.copyfile(srcpath, dstpath)

答案 1 :(得分:2)

以下是我用来解决问题的脚本:

import os
import arcpy
import os.path
import shutil
featureclass = "C:\\work_Data\\Export_Output.shp"
src = "C:\\Data\\UC_Training_Areas"
dst = "C:\\Data\\Script"

rows = arcpy.SearchCursor(featureclass)
row = rows.next()
while row:
     print row.Label
     shutil.move(os.path.join(src,str(row.Label)),dst)
     row = rows.next()

答案 2 :(得分:1)

想一想这种方式来源和目的地 假设您要将文件从图片文件夹复制到位于机器目的地某处的图像文件夹中 X是您的机器名称 Z是文件名``

import os;
import shutil;
import glob;

source="C:/Users/X/Pictures/test/Z.jpg"
dest="C:/Users/Public/Image"

    if os.path.exists(dest):
    print("this folder exit in this dir")
else:
    dir = os.mkdir(dest)

for file in glob._iglob(os.path.join(source),""):
    shutil.copy(file,dest)
    print("done")