我对Python(3)还是很陌生的。我有一堆传感器数据,但下载限制迫使我以块的形式检索数据,而不是一次检索所有数据(下载的每个.zip文件都包含一个文件夹,其中包含给定时间段内每个传感器数据的.csv文件)。因此,我有几十个大的.csv文件分布在几个文件夹中,我最终想将这些文件合并/合并/附加到每个传感器的完整数据的一个.csv文件中。更复杂的是,每个传感器的.csv文件名在文件夹中是相同的。我开发了以下代码来重命名并将文件移动到一个文件夹中,以便以后可以concat/merge/append。它工作得很好,除了我插入新文件名的数字没有增加。在import os
path = r"C:\directory\sensordatafolders" #folders with .csv files
newPath = r"C:\directory\new" #destination for renamed files
for root, dirs, files in os.walk(path):
for name in files:
base, extension = os.path.splitest(name)
if not os.path.exists(os.path.join(newPath, base + extension))
oldfile = os.path.join(os.path.abspath(root), name)
newfile = os.path.join(newPath, base + extension)
os.rename(oldfile, newfile)
else:
i = 1
oldfile = os.path.join(os.path.abspath(root), name)
newfile = os.path.join(newPath, base + '_' + str(i) + extension)
i +=1
os.rename(oldfile, newfile)
在第二个循环(*.csv和*\u 1.csv文件成功移动)之后,它给出“当文件已存在时无法创建文件”错误。这是因为(我认为)它一直试图创建*\u 1.csv文件,而不是递增到*\u 2.csv等等。。在