Ответ 1
Проблема в том, что вы ничего не делаете с результатом replace
. В Python строки неизменяемы, поэтому все, что манипулирует строкой, возвращает новую строку вместо изменения исходной строки.
line[8] = line[8].replace(letter, "")
Я читаю 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
не работает.
Есть ли лучший способ сделать это?
Проблема в том, что вы ничего не делаете с результатом 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))