如何替换字符串中某个字符的所有出现?

80 投票
3 回答
154485 浏览
提问于 2025-04-16 03:24

我正在把一个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这个函数没有起作用。

有没有更好的方法来做到这一点?

3 个回答

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

我会使用不带翻译表的translate方法。在最近的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]
124

问题在于你没有对 replace 的结果做任何处理。在Python中,字符串是不可改变的,这意味着任何对字符串的操作都会返回一个新的字符串,而不会直接修改原来的字符串。

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

撰写回答