У меня есть следующий код:
text = 'hello world 2,000 3,000'
text = text.replace(' ', '|')
print text
Вывод:
hello|world|2,000|3,000
Я хочу разграничить использование '|' но я хочу, чтобы результат был в трех столбцах. Я не хочу, чтобы слова были отделены друг от друга, просто слова из чисел:
hello world|2,000|3,000
Как я могу это сделать?
Используйте замену регулярных выражений:
import re
text = 'hello world 2,000 3,000'
print re.sub(r'\s(\d)', '|\\1', text)
Это только вставляет метку трубы для вещей, которым предшествует пробел и цифра.
У вас есть три поля, разделенные пробелами, и первое поле также может содержать пробелы. Вы можете использовать rsplit
с аргументом maxsplit, чтобы разделить строку на три части справа.
text = 'hello world 2,000 3,000'
# Split at the two rightmost spaces, so that
# the leftmost of the three fields can contain spaces
parts = text.rsplit(' ', 2) # ['hello world', '2,000', '3,000']
result = '|'.join(parts) # 'hello world|2,000|3,000'
Если вы не хотите регулярное выражение, вы это делаете: Это предполагает, что у вас много строк ввода и их все в списке списков. Он возвращает список списков, где каждый элемент является правильно проанализированной строкой.
Это только предполагает, что ваши поля разделены пробелом и что вы не хотите иметь трубку между двумя первыми полями.
# one line of input
text = 'hellow world 1,000 2,000'
testlist = text.split(' ')
# all your input
list_of_all_text = [testlist] + [testlist] + [testlist]
first_feilds = map(lambda x: x[0]+' '+x[1],list_of_all_text)
last_feilds = map(lambda x: x[2:],list_of_all_text)
all_feilds = map(lambda x,y: [x]+y,first_feilds,last_feilds)
parsed_feilds = map(lambda x: '|'.join(x),all_feilds)
print parsed_feilds
или менее читаемый и более компактный:
text = 'hellow world 1,000 2,000'
testlist = text.split(' ')
list_of_all_text = [testlist] + [testlist] + [testlist]
map(lambda x: '|'.join(x),map(lambda x,y: [x]+y,map(lambda x: x[0]+' '+x[1],list_of_all_text),map(lambda x: x[2:],list_of_all_text)))