我对Python(3)还是很陌生.我有大量的传感器数据,但是下载限制迫使我分块而不是一次全部检索数据(下载的每个.zip文件都包含给定时间段内每个传感器数据的.csv文件文件夹).因此,我有几十个大的.csv文件分布在几个文件夹中,我最终希望将它们合并/合并/附加到每个传感器的全部数据的一个.csv文件中.为了使事情变得更复杂,每个传感器的.csv文件名在文件夹中相同.我开发了以下代码来将文件重命名并将其移动到一个文件夹中,以便以后可以合并/合并/追加.除了我要插入新文件名中的数字没有递增的事实外,它工作正常.
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和* _1.csv文件已成功移动)之后,它提示我“该文件已存在时无法创建文件”错误.这是因为(我认为)它一直在尝试创建* _1.csv文件,而不是增加到* _2.csv等.
解决方法:
你的
i = 1
在其他地方不应该出现之后,它将i设置为1,因此总是使i的值设置为2,尝试将其放在for语句之外
标签:os-path,python,increment
来源: https://codeday.me/bug/20191013/1905450.html