如何替换字符串中所有特定字符的出现?

78

我正在将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

我想要将行中第八个元素中所有出现的['a', 'b', 'c', 'd']替换为空字符串。但是remove_chars函数不起作用。

有更好的方法吗?


第八个元素是line[7],因为索引从0开始。 - Tony Veijalainen
3个回答

123

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

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

1

我会使用没有翻译表的翻译方法。在最近的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]

一个像 remove_chars 这样简单的函数通常不应该破坏性地修改全局变量的值。 - OTZ
我让这个函数返回修改后的行。 - Tony Veijalainen
感谢 - 更高效,但需要注意的是,正如 https://dev59.com/cWgt5IYBdhLWcg3w8h_e 中所述,translate 方法在处理 Unicode 字符串时有所不同。因此,如果您只需要替换一个字符,则使用 replace 方法可能更好,因为它对字符串和 Unicode 都适用。 - nealmcb

0

你真的应该有多个输入框,例如一个用于输入名字,中间名和姓,另一个用于输入年龄。不过如果你想玩一下,可以尝试:

>>> 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))

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接