如何替换字符串中某个字符的所有匹配项?

我正在把 CSV 读入 a:

import csv
import collections
import pdb
import math
import urllib


def do_work():
a=get_file('c:/pythonwork/cds/cds.csv')
a=remove_chars(a)
print a[0:10]


def get_file(start_file): #opens original file, reads it to array
with open(start_file,'rb') as f:
data=list(csv.reader(f))
return (data)


def remove_chars(a):
badchars=['a','b','c','d']
for row in a:
for letter in badchars:
row[8].replace(letter,'')
return a

我想用空字符串替换该行第8个元素中出现的所有 ['a','b','c','d']remove_chars函数不工作。

还有更好的办法吗?

148075 次浏览

问题是,对于 replace的结果,您没有做任何事情。在 Python 中,字符串是不可变的,因此任何操作字符串的操作都会返回一个新字符串,而不是修改原始字符串。

line[8] = line[8].replace(letter, "")

我将使用没有转换表的翻译方法,它删除了最近 Python 版本中第二个参数中的字母。

def remove_chars(line):
line7=line[7].translate(None,'abcd')
return line[:7]+[line7]+line[8:]


line= ['ad','da','sdf','asd',
'3424','342sfas','asdfaf','sdfa',
'afase']
print line[7]
line = remove_chars(line)
print line[7]

你真的应该有多个输入,例如一个用于名字,中间名,姓氏和另一个用于年龄。如果你想找点乐子,你可以试试:

>>> input_given="join smith 25"
>>> chars="".join([i for i in input_given if not i.isdigit()])
>>> age=input_given.translate(None,chars)
>>> age
'25'
>>> name=input_given.replace(age,"").strip()
>>> name
'join smith'

当然,如果输入中有多个数字,这将会失败。快速检查如下:

assert(age in input_given)

还有:

assert(len(name)<len(input_given))