0 / 0 / 0
Регистрация: 03.04.2018
Сообщений: 24

Импорт таблицы csv в базу SQLite3

08.12.2019, 22:06. Показов 12289. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрые люди!....

Использую Python 3.7.3 PyCharm 2018.3.6 (Community Edition)
Возникла необходимость перенести файл DBF-структуры в базу данных SQLite, используя Python.
( Наверное, существует много вариантов решения такой задачи самой по себе, но захотелось решить ее с помощью импорта файла CSV-структуры, полученного из DBF-файла. Нужно освоить эту технологию саму по себе.)

Есть тестовая база 'baza_sqlite.db' в SQLite
Есть тестовый файл 'input_file.csv', который нужно конвертировать в SQLite.
Файл содержит в себе три поля p1,p2,p3 и три тестовые строки типа 1, Term 1, Definition 1.

Желая исполнить свое намерение , запускаю такой вот скрипт в файле "csvinbaza.py" :


1 # -*- coding: utf-8 -*-
2 import csv, sqlite3
3 class csvrd:
4 def csvFile(self,filename):
5 self.readFile(filename)
6
7 def readFile(self,filename):
8 conn = sqlite3.connect('baza_sqlite.db')
9 cur = conn.cursor()
10
11 cur.execute("""CREATE TABLE IF NOT EXISTS test000(p1 varchar,p2 varchar,p3 varchar)""")
12 filename.encode('utf-8')
13 with open(filename) as f:
14 reader = csv.reader(f)
15 for row in reader:
16 cur.execute("INSERT INTO test000 VALUES (?,?,?)", row.split("|"))
17
18 conn.commit()
19 conn.close()
20
21 c = csvrd().csvFile('input_file.csv')

При попытке выполнить этот скрипт (или его какие-то варианты), всякий раз получаю такую ошибку:


Traceback (most recent call last):
File "E:/MyPython/F066_GB3/csvinbaza.py", line 21, in <module>
c = csvrd().csvFile('input_file.csv')
File "E:/MyPython/F066_GB3/csvinbaza.py", line 5, in csvFile
self.readFile(filename)
File "E:/MyPython/F066_GB3/csvinbaza.py", line 15, in readFile
for row in reader:
ValueError: I/O operation on closed file.

Process finished with exit code 1

Судя по всему, пробалема в строке 15: " for row in reader:". Но тусуюсь вокруг нее третьи сутки, а выкрутиться не получается.
Тестовая таблица test000 в базе создается, на записи в созданные поля не переносятся. Пробовал разные разделители в СSV
файле: ",", ";", "|". Не помогает.
Шарил по Гуглу. Ничего не нашел, попадавшиеся примеры чаще относятся к версии Python 2.*

Может быть кто-нибудь поспособствует мне преодолеть возникшее затруднение? Опыт работы с Питоном минимальный.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.12.2019, 22:06
Ответы с готовыми решениями:

Импорт файла в базу данных через sqlite3
Всем привет. Нужно загрузить текстовый файл в базу данных кол-во строк 4млн, вес файла 58 мб. Написал вот такой код ...

Импорт данных в базу из файла .csv
Добрый день, уважаемые форумчане мне нужна помощь. Мне нужен запрос который импортирует данные из файла .csv в базу. У меня почему-то...

Импорт из csv в базу данных посредством php скрипта
Привет, друзья. Есть php скрипт &lt;?php $file_name = 'сайт.ру/uploads/files/content.csv'; // абсолютный путь до файла //$file_name =...

2
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
09.12.2019, 13:17
Лучший ответ Сообщение было отмечено vylv137 как решение

Решение

Возможно, проблема с отступами в коде (файл закрылся, а вы его читаете). Попробуйте для начала вывести содержимое файла на экран:

Python
1
2
3
with open('input_file.csv') as f:
    for row in csv.reader(f):
        print(row)
Добавлено через 1 минуту
Вот что говорит документация:
Python
1
2
3
4
5
6
7
>>> import csv
>>> with open('eggs.csv', newline='') as csvfile:
...     spamreader = csv.reader(csvfile, delimiter=' ', quotechar='|')
...     for row in spamreader:
...         print(', '.join(row))
Spam, Spam, Spam, Spam, Spam, Baked Beans
Spam, Lovely Spam, Wonderful Spam
1
0 / 0 / 0
Регистрация: 03.04.2018
Сообщений: 24
09.12.2019, 18:27  [ТС]
Благодарю! Вы были правы относительно отступов!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.12.2019, 18:27
Помогаю со студенческими работами здесь

Как лучше всего реализовать импорт CSV в базу данных с предпросмотром?
Я хочу сделать импортирование CSV в базу данных, структура у CSV будет обычная, по типу: фио(с пробелами, по ним буду делать массив из...

Импорт таблицы из csv в БД Access
Всем привет Нужне собсна сабж Структура csv заранее неизвестна, надо импортнуть csv в виде таблицы в Access, и там её уже разбирать...

Импорт данных из csv файла в таблицы БД
Здравствуйте. Помогите пожалуйста реализовать следующее. У меня есть база данных в ней находится 3 таблицы (схему бд прикрепил). У меня...

Импорт в базу на oracle из большого *.csv файла без доступа к файлам сервера и sqlldr.exe
Если кратко, то просто хочется понять есть ли какие методы загрузки больших файлов csv ( &gt; 700 Mb) через чистый sql или нет? ---- А...

Необычный импорт таблицы в базу
Получаю по почте файл (во вложении), содержащий таблицу. В таблице в вертикально объединенных ячейках содержатся числовые данные...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru