Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/40: Рейтинг темы: голосов - 40, средняя оценка - 4.95
0 / 0 / 1
Регистрация: 28.12.2016
Сообщений: 56

Работа с Excel

03.05.2018, 12:29. Показов 7607. Ответов 12
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Работаю с файлом Excel: записываю информацию на разные листы. Затем сохраняю файл с помощью функции save() и закрываю с помощью функции close(). Файл сохраняется и закрывается, но остается открытым само приложение Excel...
Может кто-нибудь знает как его закрыть?
Для записи данных в Excel использую библиотеку xlwings.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.05.2018, 12:29
Ответы с готовыми решениями:

Работа с документами Excel без Microsoft.Office.Interop.Excel
всем добрый день все дело в том что для своих программ я использую БД Excel но! однако не все устанавливают на компьютере Office, да и...

Работа с Excel (нет доступа к пространству имен Excel)
Здравствуйте! У меня проблема в том, что я делаю все так как там, но выдает ошибку в строчках на слова Excel, например: ...

Работа с Excel через Microsoft.Office.Interop.Excel
Необходимо реализовать програмку взаимодействующую с Excel в режиме реального времени. Проблем несколько: 1. Как сделать так,...

12
1740 / 912 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
03.05.2018, 12:46
Цитата Сообщение от daria13 Посмотреть сообщение
но остается открытым само приложение Excel
Не удается добиться такого поведения, Excel закрывается, приведите минимальный код который не закрывает Excel
0
Эксперт Python
 Аватар для dondublon
4643 / 2059 / 363
Регистрация: 17.03.2012
Сообщений: 10,139
Записей в блоге: 6
03.05.2018, 16:20
xl.quit()?
0
0 / 0 / 1
Регистрация: 28.12.2016
Сообщений: 56
12.05.2018, 19:58  [ТС]
Цитата Сообщение от ТабуретY Посмотреть сообщение
минимальный код который не закрывает Excel
Код:
Python Скопировано
1
2
3
4
5
import xlwings as xw
wb = xw.Book('File.xlsx')
#открываю некоторые листы и записываю в них информацию из списков
wb.save()
wb.close()
Закрывает файл, но остается то, что на приложенной картинке. Может быть есть способ открывать файл Excel вообще в фоновом режиме?

Цитата Сообщение от dondublon Посмотреть сообщение
xl.quit()
он ее не понимает с такой библиотекой.
Миниатюры
Работа с Excel  
0
Эксперт Python
 Аватар для dondublon
4643 / 2059 / 363
Регистрация: 17.03.2012
Сообщений: 10,139
Записей в блоге: 6
14.05.2018, 11:05
daria13, а вы точно вызываете quit у объекта-приложения, а не книги?
0
Эксперт Python
5437 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
14.05.2018, 14:04
На винде нужно либо делать app.kill(), либо удалять объект приложения после quit():
Python Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
import time,os
import xlwings as xw
 
app = xw.App(visible=False) # режим без видимого GUI
PID = app.pid
print(os.system('tasklist /FI "PID eq %d"' % PID)) # для теста смотрим наличие процесса 
time.sleep(3)
#app.kill()  # просто убиваем процесс средствами ос
app.quit()   # или все таки культурно предлагаем процессу закруглиться и затем удаляем ссылку на объект
del app  # если не удалить ссылку на объект - процесс будет висеть до выхода из скрипта
print('quit excel')
print(os.system('tasklist /FI "PID eq %d"' % PID)) # процесс должен исчезнуть
time.sleep(30)
Добавлено через 47 минут
P.S. Почему-то с открытой книгой (которой мы потом сделали close) вариант с
Python Скопировано
1
2
app.quit()
del app
не работает.
Только app.kill()
0
Эксперт Python
 Аватар для dondublon
4643 / 2059 / 363
Регистрация: 17.03.2012
Сообщений: 10,139
Записей в блоге: 6
14.05.2018, 14:21
Цитата Сообщение от Garry Galler Посмотреть сообщение
app.quit()
del app
не работает.
Я как-то сто лет назад с подобным сталкивался.
При close он воспроизводит поведение обычного екселя, а именно - выдаёт гуишное окошко "сохранить - не сохранять - отмена" и так с ним и висит. В этом состоянии таки да, только kill

Добавлено через 2 минуты
Да, кстати, с quit-ом та же петрушка.
0
0 / 0 / 1
Регистрация: 28.12.2016
Сообщений: 56
24.05.2018, 11:50  [ТС]
Цитата Сообщение от Garry Galler Посмотреть сообщение
app = xw.App(visible=False) # режим без видимого GUI
У меня вообще ничего не получилось... Ни с невидимостью, ни с kill().Я так поняла, это потому что я вызываю книгу... Он говорит что для Book() он не знает App()
Python Скопировано
1
wb = xw.Book('Название файла.xlsx')
0
Эксперт Python
 Аватар для dondublon
4643 / 2059 / 363
Регистрация: 17.03.2012
Сообщений: 10,139
Записей в блоге: 6
24.05.2018, 13:27
чего-чего он говорит?
0
0 / 0 / 1
Регистрация: 28.12.2016
Сообщений: 56
24.05.2018, 13:33  [ТС]
Цитата Сообщение от dondublon Посмотреть сообщение
чего-чего он говорит?
Забыла прикрепить ошибку
AttributeError: 'Book' object has no attribute 'App'
0
Эксперт Python
 Аватар для dondublon
4643 / 2059 / 363
Регистрация: 17.03.2012
Сообщений: 10,139
Записей в блоге: 6
24.05.2018, 14:05
Но я не вижу, чтобы атрибут App где-то запрашивался.
0
Эксперт Python
5437 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
24.05.2018, 14:09
Лучший ответ Сообщение было отмечено daria13 как решение

Решение

daria13,
А документацию прочитать?
Естественно, такого атрибута у книги нет. Но никто и не говорил, что все эти методы нужны применять к Book.
Впрочем, у каждого экземпляра Book есть атрибут book.app - то есть доступ к уже запущенному экземпляру приложения. И к нему также можно применять все методы класса App.
Но при использовании такого способа доступа
Python Скопировано
1
2
3
book = xw.Book("1.xlsx")
app = book.app
app.visible = False
у вас приложение сначала запустится в видимом режиме и только через 1-2 секунды станет невидимым.
А если напрямую создавать экземпляр приложения и обращаться к нему - тогда Excel будет сразу запущен в невидимом режиме.
1
0 / 0 / 1
Регистрация: 28.12.2016
Сообщений: 56
30.05.2018, 10:13  [ТС]
Цитата Сообщение от Garry Galler Посмотреть сообщение
Естественно, такого атрибута у книги нет
Спасибо большое)
Буду стараться читать внимательнее
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.05.2018, 10:13
Помогаю со студенческими работами здесь

Работа с Excel. Суть: Если номер строки в Excel четный тогда объеденяем эту ячейку с последующей.
Здравствуйте. Помогите, пожалуйста .Я вот в Delphi осуществляю работу с документов в Excel, как я могу записать, чтобы выполнялся алгоритм:...

Большая работа с Excel (передача в него данных, построение графиков, дозапись, создание нового файла Excel)
Всем участниками большой привет. Снова нужна помощь. Что имеем: -Имеем форму во вложении. на ней есть 30 нужных нам текстбоксов,...

Экспорт в Excel: Прекращена работа программы "Microsoft Excel"
Файл сохраняется успешно, но поле строки excelApp.Quit(); Появляется окно ошибки Excel: Прекращена работа программы "Microsoft...

Работа с Excel и "висячий процесс" EXCEL
Доброго времени суток. Помогите решить следующие проблемы. Создаю процесс Excel и создаю рабочую книгу: try {// Присоединение к...

работа в Excel
Задание по информатике Что-то вроде создания турфирмы Выглядеть это должно вот так...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели. Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
На любовном киберфронте
Alexander-7 01.04.2025
Недавно на одном малоизвестном сайте знакомств мною заинтересовалась девушка: «Текст немного странный. Но, судя по адресу почты, иностранка», – подумал я. Поколебавшись пару суток, я ответил ей:. . .
Как работает Node.js изнутри
run.dev 29.03.2025
Node. js изменил подход к разработке веб-приложений, позволив использовать JavaScript не только на стороне клиента, но и на сервере. Созданный в 2009 году Райаном Далем, этот открытый,. . .
Моки в Python: Mock Object Library
py-thonny 29.03.2025
Тестирование кода требует особого подхода, когда речь идёт о компонентах, взаимодействующих с внешним миром. Мы часто сталкиваемся с непредсказуемостью HTTP-запросов, чтением данных из базы или. . .
JavaScript: Управление памятью и улучшение производительности
run.dev 29.03.2025
В отличие от низкоуровневых языков программирования, JavaScript не требует ручного выделения и освобождения памяти. Здесь работает автоматический сборщик мусора, который определяет, какие объекты. . .
Мультитенантная архитектура со SpringBoot и PostgreSQL
ArchitectMsa 29.03.2025
SaaS-приложения редко обслуживают одного клиента и обычно они должны поддерживать множество организаций, каждая из которых работает в своём изолированном пространстве. Мультитенантная архитектура. . .
std::span в C++: Производительность и лучшие практики
NullReferenced 28.03.2025
std::span — одно из самых недооценённых нововведений стандарта C++20, которое радикально меняет подход к работе с непрерывными последовательностями данных. По сути, это невладеющее представление. . .
Многопоточность в C#: Threadpool
UnmanagedCoder 28.03.2025
Пул потоков в C# — это коллекция заранее созданных и готовых к использованию потоков, которые находятся в распоряжении приложения. Вместо того чтобы создавать и уничтожать потоки для каждой небольшой. . .
Вопросы на собеседованиях по микросервисам
ArchitectMsa 27.03.2025
Работодатели ищут не просто разработчиков, знающих базовые концепции, а специалистов, разбирающихся в тонкостях масштабирования, отказоустойчивости и производительности. Сейчас на первый план выходят. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер