170 похожих чатов

Приветствую всех, как при работе с csv мне выбрать определённую

книгу?



Читал тут, но либо у меня с глазами беда, либо тупо не написано о работе с разными книгами
https://docs.python.org/3.10/library/csv.html

10 ответов

21 просмотр

А что значит разные книги в csv? Это же обычеый текстовый файл

denis- Автор вопроса

Не всегда. В excel так уж точно

denis
Не всегда. В excel так уж точно

Это разные веши xlsx - это архив с xml файлами csv - это обычный текстовый файл

denis- Автор вопроса
Pavel Aksenov
Это разные веши xlsx - это архив с xml файлами csv...

Хорошо. НО, есть файл csv хранящий в себе несколько книг. Если вы можете предоставить пример работы с xlsx на манер как сделано на скриншоте - буду благодарен. Необходимо считывать данные с excel и импортировать эти данные в таблицы БД

denis
Хорошо. НО, есть файл csv хранящий в себе нескольк...

Сложно понять, что надо. Сначала хочется разобраться с форматом файла, а уже потом искать решение. Так что за файл csv или xlsx? Если csv, то код выглядит рабочим

denis- Автор вопроса
Pavel Aksenov
Сложно понять, что надо. Сначала хочется разобрать...

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

denis
screenshot Вот что делает данный код. Повторюсь, если данный ...

Для работы с ексель файлами можно использовать https://openpyxl.readthedocs.io/en/stable/ Тут есть возможность переходить по Книгам и читать построчно wb = load_workbook(file_path) sheet = wb.active end_row = sheet.max_row end_col = sheet.max_column for i in range(end_row + 1): cell_values = [] for j in range(end_col + 1): cell = sheet.cell(row=i, column=j) cell_values.append(cell.value) Вот кусок накидал (нерабочий скорее всего) Тут еще нужен будет один цикл for чтобы переключать Книги

denis- Автор вопроса
Pavel Aksenov
Для работы с ексель файлами можно использовать htt...

Спасибо, что натолкнули на мысль того, что по сути описание одинаковое для этих двух библиотек Реализовал на манер предыдущего способа без цикла по книгам. Но решил повторить ваш код (больно мне понравилось, что можно не прописывать каждое поле отдельно) Правда я не совсем понимаю как избавиться от необходимости каждое поле прописывать

denis
screenshot Спасибо, что натолкнули на мысль того, что по сути...

так как в xlsx нельзя(или я не умею) читать построчно, то заведена переменная cell_values, которая создаётся на каждую строку. Во вложенном for она заполняется. И после выхода из вложенного for получается список всех значений из строки. И именно после выхода из вложенного for можно создать/соханить запись в бд

denis
screenshot Спасибо, что натолкнули на мысль того, что по сути...

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

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта