|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
24.06.2009, 21:35 | #1 |
Форумчанин
Регистрация: 25.08.2008
Сообщений: 159
|
сохранение
Еще раз здраствуйте.
Вопрос на повестке дня: есть код, который при сохранении книги отключает обновление экрана и уже в фоновом режиме активирует нужный лист (в котором написано, что надо сделать если отключены макросы) и сохраняет книгу (соответственно при открытии книги этот лист скрывается), вот код: Код:
|
25.06.2009, 05:02 | #2 | ||
Старожил
Регистрация: 05.12.2007
Сообщений: 4,180
|
Цитата:
Цитата:
Чем шире угол зрения, тем он тупее.
|
||
25.06.2009, 13:15 | #3 | |
Форумчанин
Регистрация: 25.08.2008
Сообщений: 159
|
Цитата:
Если принудительно сделать thisWorkbook.Saved=true - то Excel думает что книга сохранена и закрывает без вопросов. Я делаю thisWorkbook.Saved=true перед последним предложением Cancel=true, но сразу после этого любой Sub проверкой thisWorkbook.Saved=false! В книге ничего изменилось, я просто после сохранения сразу запускаю тестовый Sub и он мне пишет что thisWorkbook.Saved=false. Почему? А почему я подумал, что cancel=true, так потому, что ведь после завершения обработки события BeforSave, даже при возвращеном Cancel=true, сама функция сохранения продолжается, которая и считывает возвращенное значение. И если вернулось Cancel=true, то ексель не сохраняет книгу, а присваивет ThisWorkbook.saved=false, так как книга не была сохранена. и в результате после отмененного события сохранения получается что ThisWorkbook.saved=false. Просто я больше не как не могу понять ситуацию. Последний раз редактировалось tolikman; 25.06.2009 в 13:23. |
|
26.06.2009, 06:37 | #4 |
Старожил
Регистрация: 05.12.2007
Сообщений: 4,180
|
Вставьте в модуль "Эта книга" код:
Код:
Чем шире угол зрения, тем он тупее.
Последний раз редактировалось SAS888; 26.06.2009 в 09:53. |
27.06.2009, 19:40 | #5 |
Форумчанин
Регистрация: 25.08.2008
Сообщений: 159
|
Да это понятно. Но мне необходимо следить за изменениями, и просто закрыть без сохранения нельзя. Надо спрашивать пользователя в случае наличия несохраненных изменений о сохранении. Я уже обошел эту проблему, создав переменную BookSaved, при открытии она равна True, а при событиях которые изменяют книгу, она становиться False, и потом, при необходимости, при закрытии книги вылазеет мое сообщение-дубликат: "Сохранить или нет". Но это какая-то тофтология, ведь есть системная переменная.
|
30.06.2009, 05:23 | #6 | |
Старожил
Регистрация: 05.12.2007
Сообщений: 4,180
|
Цитата:
Чем шире угол зрения, тем он тупее.
|
|
30.06.2009, 14:49 | #7 |
Форумчанин
Регистрация: 25.08.2008
Сообщений: 159
|
спасибо, разберусь...
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Сохранение файла | KREGI | Помощь студентам | 4 | 30.03.2009 21:09 |
Сохранение результатов | program123 | Общие вопросы Delphi | 1 | 13.03.2009 22:10 |
Сохранение | Патрон | Общие вопросы Delphi | 21 | 14.12.2008 14:23 |
сохранение | 1234 | Общие вопросы Delphi | 11 | 30.08.2008 11:47 |
Сохранение | Lonix | Общие вопросы Delphi | 1 | 22.04.2007 00:15 |