我有一个文件,.csv 文件中的一些行由于行中某些字段中的时髦字符而阻塞了数据库导入。
我已经搜索过,找到了关于如何在 Python 3 中替换非 ascii 字符的文章,但没有任何效果。
当我在 vi 中打开文件并执行 :set list 时,在不应该存在的行的末尾有一个 $,而在下一行的开头有 ^I^I。这两行应该是一条连线,没有 ^I 。我知道 $ 是行的结尾 '\n' 并试图替换它们,但没有任何效果。
我不知道 ^I 代表什么,可能是一个制表符。
我试过这个功能无济于事:
def remove_non_ascii(text):
new_text = re.sub(r"[\n\t\r]", "", text)
new_text = ''.join(new_text.split("\n"))
new_text = ''.join([i if ord(i) < 128 else ' ' for i in new_text])
new_text = "".join([x for x in new_text if ord(x) < 128])
new_text = re.sub(r'[^\x00-\x7F]+', ' ', new_text)
new_text = new_text.rstrip('\r\n')
new_text = new_text.strip('\n')
new_text = new_text.strip('\r')
new_text = new_text.strip('\t')
new_text = new_text.replace('\n', '')
new_text = new_text.replace('\r', '')
new_text = new_text.replace('\t', '')
new_text = filter(lambda x: x in string.printable, new_text)
new_text = "".join(list(new_text))
return new_text
是否有一些工具可以准确地告诉我这个令人讨厌的角色是什么,然后找到一种方法来替换它?
我像这样打开文件(.csv 被保存为 UTF-8)
f_csv_in = open(csv_in, "r", encoding="utf-8")
下面是两行,应该是问题非 ascii 字符可见的一行。
这两行应该是一行。注意第 37 行末尾的 $,第 38 行以 ^I^I 开头。
vi 显示的部分问题是第 37 行有一个新行 $,我不希望它出现在那里。这应该是一行。
37 Cancelled,01-19-17,,basket,00-00-00,00-00-00,,,,98533,SingleSource,,,17035 Cherry Hill Dr,"L/o 1-19-17 @ 11:45am$
38 ^I^IVictorville",SAN BERNARDINO,CA,92395,,,,,0,,,,,Lock:6111 ,,,No,No,,0.00,0.00,No,01-19-17,0.00,0.00,,01-19-17,00-00-00,,provider,,,Unread,00-00-00,,$
哔哔one
冉冉说
相关分类