Как я могу объединить список в строку (предостережение)?
В дополнение к моему предыдущему вопросу, как я могу объединить список строк в строку, чтобы значения были правильно указаны в кавычках. Что-то вроде:
['a', 'one "two" three', 'foo, bar', """both"'"""]
в:
a, 'one "two" three', "foo, bar", "both\"'"
Я подозреваю, что модуль CSV войдет в игру здесь, но я не уверен, как получить вывод, который я хочу.
3 ответа
С использованием csv
Модуль вы можете сделать так:
import csv
writer = csv.writer(open("some.csv", "wb"))
writer.writerow(the_list)
Если вам нужна строка, просто используйте StringIO
экземпляр в виде файла:
f = StringIO.StringIO()
writer = csv.writer(f)
writer.writerow(the_list)
print f.getvalue()
Выход: a,"one ""two"" three","foo, bar","both""'"
csv
напишу так, как он может прочитать позже. Вы можете точно настроить его вывод, определив dialect
Просто установите quotechar
, escapechar
и т. д. по мере необходимости:
class SomeDialect(csv.excel):
delimiter = ','
quotechar = '"'
escapechar = "\\"
doublequote = False
lineterminator = '\n'
quoting = csv.QUOTE_MINIMAL
f = cStringIO.StringIO()
writer = csv.writer(f, dialect=SomeDialect)
writer.writerow(the_list)
print f.getvalue()
Выход: a,one \"two\" three,"foo, bar",both\"'
Тот же диалект можно использовать с модулем csv для чтения строки позже в список.
На заметку о том, что встроенные кодеры Python также могут выполнять экранирование строк:
>>> print "that's interesting".encode('string_escape')
that\'s interesting
Вот немного более простая альтернатива.
def quote(s):
if "'" in s or '"' in s or "," in str(s):
return repr(s)
return s
Нам нужно только заключить в кавычки значение, которое может иметь запятые или кавычки.
>>> x= ['a', 'one "two" three', 'foo, bar', 'both"\'']
>>> print ", ".join( map(quote,x) )
a, 'one "two" three', 'foo, bar', 'both"\''