|
7 / 7 / 2
Регистрация: 21.02.2019
Сообщений: 134
|
||||||||||||||||
Builder 6 Сохранение файла Excel, заполненного из не основного потока12.04.2019, 13:18. Показов 1595. Ответов 8
Метки нет (Все метки)
Доброго всем времени суток, господа.
Помогите решить следующею проблемку. Данный код, открывает файл Excell только в режиме для чтения. И какие бы манипуляции с таблицей я не проводил бы, после сохранения ничего не сохраняется. Открытие, редактирование выполняю не из основного потока программы. Код открытия:
Сохранение:
Вызов метода открытия:
0
|
||||||||||||||||
| 12.04.2019, 13:18 | |
|
Ответы с готовыми решениями:
8
Выполнение слота основного потока через сигнал второстепенного потока
Сохранение файла на уровне потока |
|
7 / 7 / 2
Регистрация: 21.02.2019
Сообщений: 134
|
|||
| 12.04.2019, 13:47 [ТС] | |||
|
Добавлено через 21 минуту
0
|
|||
|
Супер-модератор
|
||
| 12.04.2019, 15:38 | ||
|
CoInitialize у тебя вызывается, а CoUninitialize - нет, а ведь:
Ну, а то, что ты работаешь из дополнительного потока с GUI-потоком без синхронизации я уже написал выше. Это к добру не приведет, используй Synchronize(), хотя тогда я не понимаю, зачем тебе нужен дополнительный поток.
1
|
||
|
7 / 7 / 2
Регистрация: 21.02.2019
Сообщений: 134
|
||
| 12.04.2019, 16:40 [ТС] | ||
|
Спасибо.
0
|
||
|
Супер-модератор
|
|
| 12.04.2019, 17:32 | |
|
Так вот это очень плохой план. Форма и все визуальные компоненты, которые на ней находится, обязаны работать в контексте основного (GUI) потока (потому что компоненты в VCL НЕ потокобезопасны), и получается, что обновление ProgressBar-а нужно выносить в отдельный метод, и выполнять его через функцию Synchronize дополнительного потока, чтобы потом не было сюрпризов. Точно так же, нужно все действия с формой (показ, обновление, удаление) делать в контексте этого же, основного потока. Вот и получается, что тебе надо через Synchronize() вызывать все содержимое Execute(), а это сводит на нет преимущества дополнительного потока. Мало того, это еще и усложняет работу программы.
Ну, или полностью перерабатывать код, чтобы можно было синхронизировать только те участки, которые работают с визуальными компонентами. А теперь вопрос: оно надо?
0
|
|
|
7 / 7 / 2
Регистрация: 21.02.2019
Сообщений: 134
|
||
| 15.04.2019, 07:22 [ТС] | ||
|
работу ProgressBar-а?
0
|
||
|
65 / 31 / 18
Регистрация: 16.03.2019
Сообщений: 84
|
||||||||||||||||||||||||||
| 15.04.2019, 11:28 | ||||||||||||||||||||||||||
|
Если нужно синхронизировать только работу прогресс-бара (код я не смотрел),
можно передавать только % выполнения заполнения документа Excell из дополнительного потока в GUI поток. Например через InterlockedExchangeAdd(..., step_Of_increment). https://docs.microsoft.com/en-... xchangeadd А на свою форму поместить таймер (TTimer), который будет с некоторой периодичностью опрашивать состояние этой переменной пусть даже через тот же InterlockedExchangeAdd(..., 0) (т.е. не изменяя значения переменной) и ставить прогресс бар в соответствии с прочитанным значением. Добавлено через 56 минут Т.е. например так: 1. Где-то объявляете переменную, видимую из обоих потоков например в классе рабочего потока:
Задавать новую позицию погресс бар, только если позиция изменилась.
0
|
||||||||||||||||||||||||||
| 15.04.2019, 11:28 | |
|
Помогаю со студенческими работами здесь
9
Сохранение заполненного шаблона word данными из access Автоматический эскпорт информации из "основного" excel файла во вспомогательные и их автообновление Вызов SaveFileDialog не из основного потока
Запись в Textbox не из основного потока Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
|
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|