Как мне создать файл CSV из базы данных в Python? - PullRequest
24 голосов
/ 14 сентября 2010

У меня есть таблица Sqlite 3 и / или MySQL с именем "клиенты" ..

Используя python 2.6, как мне создать файл csv с именем Clients100914.csv с заголовками?Excel диалект ...

Выполнение Sql: select * дает только данные таблицы, но я хотел бы заполнить таблицу с заголовками.

Как создать набор записей для получения заголовков таблицы.Заголовки таблиц должны исходить непосредственно из sql, не написанного на python.

w = csv.writer(open(Fn,'wb'),dialect='excel')
#w.writelines("header_row")
#Fetch into sqld
w.writerows(sqld)

Этот код оставляет меня с открытым файлом и без заголовков.Также не могу понять, как использовать файл в качестве журнала.

Ответы [ 7 ]

55 голосов
/ 22 сентября 2010
import csv
import sqlite3

from glob import glob; from os.path import expanduser
conn = sqlite3.connect( # open "places.sqlite" from one of the Firefox profiles
    glob(expanduser('~/.mozilla/firefox/*/places.sqlite'))[0]
)
cursor = conn.cursor()
cursor.execute("select * from moz_places;")
#with open("out.csv", "w", newline='') as csv_file:  # Python 3 version    
with open("out.csv", "wb") as csv_file:              # Python 2 version
    csv_writer = csv.writer(csv_file)
    csv_writer.writerow([i[0] for i in cursor.description]) # write headers
    csv_writer.writerows(cursor)

PEP 249 (DB API 2.0) содержит дополнительную информацию о cursor.description.

9 голосов
/ 14 сентября 2010

Использование CSV-модуля очень прямолинейно и предназначено для этой задачи.

import csv
writer = csv.writer(open("out.csv", 'w'))
writer.writerow(['name', 'address', 'phone', 'etc'])
writer.writerow(['bob', '2 main st', '703', 'yada'])
writer.writerow(['mary', '3 main st', '704', 'yada'])

Создает именно тот формат, который вы ожидаете.

5 голосов
/ 14 сентября 2010

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

Если он из базы данных, вы можете также просто использовать запрос из вашего клиента sqlite:

sqlite <db params> < queryfile.sql > output.csv

, который создаст файл CSVс разделителем табуляции.

2 голосов
/ 22 сентября 2010

Как извлечь заголовки столбцов из существующей таблицы:

Вам не нужно анализировать оператор SQL "create table". Это удачно, так как синтаксис "create table" не приятен и не чист, он уродлив.

Вы можете использовать прагму table_info. Это дает вам полезную информацию о каждом столбце в таблице, включая имя столбца.

Пример:

>>> #coding: ascii
... import sqlite3
>>>
>>> def get_col_names(cursor, table_name):
...     results = cursor.execute("PRAGMA table_info(%s);" % table_name)
...     return [row[1] for row in results]
...
>>> def wrong_way(cur, table):
...     import re
...     cur.execute("SELECT sql FROM sqlite_master WHERE name=?;", (table, ))
...     sql = cur.fetchone()[0]
...     column_defs = re.findall("[(](.*)[)]", sql)[0]
...     first_words = (line.split()[0].strip() for line in column_defs.split(','))
...     columns = [word for word in first_words if word.upper() != "CONSTRAINT"]
...     return columns
...
>>> conn = sqlite3.connect(":memory:")
>>> curs = conn.cursor()
>>> _ignored = curs.execute(
...     "create table foo (id integer, name text, [haha gotcha] text);"
...     )
>>> print get_col_names(curs, "foo")
[u'id', u'name', u'haha gotcha']
>>> print wrong_way(curs, "foo")
[u'id', u'name', u'[haha'] <<<<<===== WHOOPS!
>>>

Другие проблемы с теперь удаленным ответом "разбирать таблицу создания SQL":

  1. Наполняется, например, create table test (id1 text, id2 int, msg text, primary key(id1, id2)) ... необходимо игнорировать не только CONSTRAINT, но и ключевые слова PRIMARY, UNIQUE, CHECK и FOREIGN (см. create table документы).

  2. Необходимо указать re.DOTALL в случае, если в SQL есть символы новой строки.

  3. В line.split()[0].strip() strip является избыточным.

1 голос
/ 29 марта 2017

Это просто и отлично работает для меня.

Допустим, вы уже подключились к своей таблице базы данных и также получили объект курсора.Так что продолжаем с этого момента.

import csv
curs = conn.cursor()
curs.execute("select * from oders")
m_dict = list(curs.fetchall())

with open("mycsvfile.csv", "wb") as f:
    w = csv.DictWriter(f, m_dict[0].keys())
    w.writerow(dict((fn,fn) for fn in m_dict[0].keys()))
    w.writerows(m_dict)
0 голосов
/ 22 сентября 2010

Вы, кажется, знакомы с Excel и хотите быть рядом с ним. Могу ли я предложить попробовать PyExcelerator ?

0 голосов
/ 14 сентября 2010

если я что-то упустил, вы просто хотите сделать что-то вроде этого ...

f = open("somefile.csv")
f.writelines("header_row")

логика для записи строк в файл (вам может понадобиться упорядочить значения и добавить запятые или каналы и т. Д...)

f.close()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...