繁体   English   中英

使用csv.reader在Python中读取一个文件,该文件在同一文件中具有两个不同的分隔符

[英]Read in Python with csv.reader a file with two different delimiter in the same file

我想将文件从MySQL导入python,但是同一文件中同一行上有两种定界符。

例如:

FIELDA_FIELDB_FIELDC; FILEDD; FIELDE; FIELDF

我可以用_; 但找不到如何做到这两者。

我努力了

csv_data = csv.reader(csvfile, delimiter=';' and '_')
csv_data = csv.reader(csvfile, delimiter=';' or'_')

我也尝试使用csv.sniffer。

但是每次仅使用一个定界符。

我应该怎么做 ?

CSV文件只能有一个定界符,因此您的方法无效。 如果无法修复损坏的文件,则可以分两个步骤读取它(假设使用Python 2):

csv_data = []
with open("file.csv", "rb") as csvfile:
    reader = csv.reader(csvfile, delimiter=";")
    for row in reader:
        new = []
        for item in row:
            new.extend(item.split("_"))
        csv_data.append(new)

该解决方案当然对诸如转义_分隔符等天真,但是它可能按预期的方式工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM