Как я могу объединить список в строку (предостережение)? - PullRequest
6 голосов
/ 23 сентября 2008

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

['a', 'one "two" three', 'foo, bar', """both"'"""]

в

a, 'one "two" three', "foo, bar", "both\"'"

Я подозреваю, что модуль CSV вступит в игру, но я не уверен, как получить желаемый результат.

Ответы [ 3 ]

7 голосов
/ 23 сентября 2008

Используя модуль 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 для последующего чтения строки в списке.

2 голосов
/ 23 сентября 2008

В соответствующей заметке встроенные кодировщики Python также могут выполнять экранирование строк:

>>> print "that's interesting".encode('string_escape')
that\'s interesting
1 голос
/ 23 сентября 2008

Вот немного более простая альтернатива.

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"\''
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...