Как заменить все вхождения определенного символа в строку?

Я читаю 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'] в 8-м элементе строки пустой строкой. функция remove_chars не работает.

Есть лучший способ сделать это?


person Alex Gordon    schedule 27.08.2010    source источник
comment
8-й элемент — это строка[7], потому что индексация начинается с 0.   -  person Tony Veijalainen    schedule 28.08.2010


Ответы (3)


Проблема в том, что вы ничего не делаете с результатом replace. В Python строки неизменяемы, поэтому все, что манипулирует строкой, возвращает новую строку вместо изменения исходной строки.

line[8] = line[8].replace(letter, "")
person Matti Virkkunen    schedule 27.08.2010

Я бы использовал метод перевода без таблицы перевода. Он удаляет буквы во втором аргументе в последних версиях 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]
person Tony Veijalainen    schedule 27.08.2010
comment
Такая простая функция, как remove_chars, вообще не должна деструктивно изменять значение глобальной переменной. - person OTZ; 28.08.2010
comment
Я заставил функцию вернуть измененную строку. - person Tony Veijalainen; 28.08.2010
comment
Спасибо - более эффективно, но к вашему сведению, как указано в stackoverflow.com/questions/11692199/ метод translate работает по-разному со строками Unicode. Поэтому, если вы делаете только один символ, replace, который одинаково работает как для строк, так и для Unicode, вероятно, предпочтительнее. - person nealmcb; 04.11.2017

У вас действительно должно быть несколько входных данных, например. один для имени, отчества, фамилии и еще один для возраста. Если вы хотите повеселиться, вы можете попробовать:

>>> 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))
person robert king    schedule 19.10.2011