Как я могу объединить список в строку (предостережение)?

В дополнение к моему предыдущему вопросу, как я могу объединить список строк в строку, чтобы значения были правильно указаны в кавычках. Что-то вроде:

['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"\''
Другие вопросы по тегам