Onu*_*bek 1 python regex linux windows
我driving_log.csv为模拟器创建的每个图像的文件路径创建了一个 CSV 文件 ( ),但当时我使用的是我兄弟的 Windows 计算机,因此现在每个图像的文件路径如下所示(其中几乎有 14000 个图像)。从 my 调用它时出现错误file.py,该文件与 CSV 文件位于同一目录中。
C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\center_2020_02_08_14_16_38_988.jpg,C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\left_2020_02_08_14_16_38_988.jpg,C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\right_2020_02_08_14_16_38_988.jpg,0,0,0,7.918889E-06
Run Code Online (Sandbox Code Playgroud)
我正在使用 Arch Linux。我想遍历每一行并将其更改为:
/home/onur/Documents/behavioral-cloning-CARLA/IMG/center_2020_02_08_14_16_38_988.jpg,left_2020_02_08_14_16_38_988.jpg,right_2020_02_08_14_16_38_988.jpg,0,0,0,7.918889E-06
Run Code Online (Sandbox Code Playgroud)
正如你所看到的,我需要接下来的一切\IMG\。
解决这个问题的最佳方法是什么?我应该只对每个字符串进行切片IMG\并获取其后面的内容还是使用正则表达式?
我已经针对该特定行尝试过此操作,看看它是否有效,但它不起作用:
string = r"C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\center_2020_02_08_14_16_38_988.jpg,C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\left_2020_02_08_14_16_38_988.jpg,C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\right_2020_02_08_14_16_38_988.jpg,0,0,0,7.918889E-06 "
new_string = string.replace(r"'C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\'", r"'/home/onur/Documents/behavioral-cloning-CARLA/IMG/'", 3)
print(new_string)
Run Code Online (Sandbox Code Playgroud)
这是输出:
C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\center_2020_02_08_14_16_38_988.jpg,C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\left_2020_02_08_14_16_38_988.jpg,C:\Users\a-ozb\Desktop\onur\behavirol-cloning-carla\IMG\right_2020_02_08_14_16_38_988.jpg,0,0,0,7.918889E-06
Run Code Online (Sandbox Code Playgroud)
如果您在 *nix 机器上运行代码,则可以使用该类PureWindowsPath:
>>> from pathlib import PureWindowsPath, PurePosixPath
>>> path = PureWindowsPath('C:\\Users\\foo\\bar')
>>> path.parts
('c:\\', 'Users', 'foo', 'bar')
>>> PurePosixPath('/usr', *path.parts[2:])
PurePosixPath('/usr/foo/bar')
Run Code Online (Sandbox Code Playgroud)
您可以将字符串替换方法应用于文本文件中的每一行,如下所示:
with open("input.csv", "r") as f_in:
with open("output.csv", "w") as f_out:
for line in f_in:
new_line = line.replace(...) # magic goes here
f_out.write("{}\n".format(new_line))
Run Code Online (Sandbox Code Playgroud)