嗨,想删除 csv 文件中的前导和尾随空格
24333, 116, 47,MCD,00000000000000000017996, 112
24333, 116, 47,MCD,00000000000000610036485, 112
24333, 116, 47,MCD,00000000000000610036485, 112
Run Code Online (Sandbox Code Playgroud)
任何人都可以帮助我尝试的代码
import csv
csvfile= open('strip.csv','r')
csvfile1= open('strip11.csv','w')
stripped = (row.strip() for row in csvfile)
reader = csv.reader(stripped,delimiter=' ')
writer= csv.writer(csvfile1)
for row in reader:
writer.writerow(row)
Run Code Online (Sandbox Code Playgroud)
神奇之处在于strip对每行记录中的每个项目进行应用。
剥离字符串通常像" abc ".strip. 要strip在手头没有实际字符串的情况下引用该方法,可以import string然后使用string.strip.
将map(string.strip, list_of_strings_to_strip)应用于strip记录中的每个项目并在列表中返回它们。
>>> import string
>>> rec = [" a ", " b ", " c "]
>>> map(string.strip, rec)
["a", "b", "c"]
Run Code Online (Sandbox Code Playgroud)
您的数据的完整工作示例:
import csv
import string
with open("data.csv") as f:
reader = csv.reader(f, delimiter=",")
with open("stripped.csv", "w") as fo:
writer = csv.writer(fo)
for rec in reader:
writer.writerow(map(string.strip, rec))
Run Code Online (Sandbox Code Playgroud)
该with open(...是所谓的上下文管理保证,所创建的文件描述符将内块执行期间获得无论可能的故障关闭。
结果文件如下所示:
24333,116,47,MCD,00000000000000000017996,112
24333,116,47,MCD,00000000000000610036485,112
24333,116,47,MCD,00000000000000610036485,112
Run Code Online (Sandbox Code Playgroud)