Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/16: Рейтинг темы: голосов - 16, средняя оценка - 4.69
2 / 2 / 2
Регистрация: 16.10.2011
Сообщений: 179

Выбор расширения в SaveDialog

05.09.2012, 12:55. Показов 3320. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Назрела проблема: на форме имеется компонент SaveDialog, который сохраняет данные из StringGrid в Excel. Он настроен следующим образом :

C++
1
2
SaveDialog1->Filter= "Файлы MSExcel (*.xlsx)|*.xlsx|Файлы MSExcel 97-2003(*.xls)|*.xls|Все файлы|*.*";
SaveDialog1->DefaultExt= "xlsx";
Мне нужно, чтобы при выборе типа файла для сохранения (с расширением xls или xlsx) в окне SaveDialog файл сохранялся с выбранным расширением, а не с расширением DefaulExt. Каким образом это можно сделать или как динамически поменять DefaultExt?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.09.2012, 12:55
Ответы с готовыми решениями:

SaveDialog
Доброе утро! Ребята помогите разобратся с проблемой!!!! Компонент SaveDialog1, не хочет сохранять данные в файл с расширение...

SaveDialog
Сохраняю текст(SaveTextDialog), открываю вижу такое:{\rtf1\ansi\ansicpg1251\deff0\deflang1049{\fonttbl{\f0\fnil\fcharset0...

SaveDialog
Добрый вечер! Подскажите,как получить с SaveDialog имя,а не путь к файлу.

8
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33192 / 21488 / 8233
Регистрация: 22.10.2011
Сообщений: 36,872
Записей в блоге: 12
05.09.2012, 13:37
Ну, так и сохраняй с именем SaveDialog1->FileName, если расширение было выбрано пользователем - то оно добавится к имени файла. А если выбрано не было - то подставится DefaultExt
0
2 / 2 / 2
Регистрация: 16.10.2011
Сообщений: 179
05.09.2012, 13:52  [ТС]
Даже при выборе расширения xls происходит сохранение в xslx

да и ещё вопрос, если я не выбираю не один из пунктов, но при выходе из приложения возникает ошибка "Assertion thread..", как от этого избавиться?
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33192 / 21488 / 8233
Регистрация: 22.10.2011
Сообщений: 36,872
Записей в блоге: 12
05.09.2012, 14:10
Цитата Сообщение от mappy89 Посмотреть сообщение
Даже при выборе расширения xls происходит сохранение в xslx
Не верю. Только что попробовал с твоей строкой фильтра - если выбрать "Файлы MSExcel 97-2003(*.xls)" - то сохраняет именно в *.xls...
Цитата Сообщение от mappy89 Посмотреть сообщение
если я не выбираю не один из пунктов
, то какой-то пункт выбирается автоматически (либо согласно значению FilterIndex, либо первый, если FilterIndex содержит значение индекса, которого в фильтре нет). Ошибка не воспроизводится. Тестируй на новом проекте. Если и там есть указанные тобой ошибки - присоединяй минимальный проект, который воспроизводит проблему.
0
2 / 2 / 2
Регистрация: 16.10.2011
Сообщений: 179
06.09.2012, 15:48  [ТС]
Файл в xls программа начала сохранять, однако при попытке открыть сохраннный таким образом файл выводится сообщение об ошибочном формате (т.е. расширение файлу даётся xls, а нужно его сохранять в xlsx).
В экселе есть возможность сохранять файл в формате более ранней версии, есть ли такая возможность сделать это из моей программы?
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33192 / 21488 / 8233
Регистрация: 22.10.2011
Сообщений: 36,872
Записей в блоге: 12
06.09.2012, 17:00
Цитата Сообщение от mappy89 Посмотреть сообщение
есть ли такая возможность сделать это из моей программы?
Всё, что Excel может сделать, ты из своей программы можешь повторить, работая через OLE:
C++
1
activeDoc.OleProcedure("SaveAs", FileName, xlExcel8 /*56*/);
запишет текущий файл в формате Excel 97-2003.
2
2 / 2 / 2
Регистрация: 16.10.2011
Сообщений: 179
14.09.2012, 13:52  [ТС]
UI у меня не заработал Ваш код, пишет что xlExcel8 - undefined var
0
0 / 0 / 0
Регистрация: 24.03.2013
Сообщений: 13
28.03.2013, 13:45
Тоже самое и у меня пишет...
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33192 / 21488 / 8233
Регистрация: 22.10.2011
Сообщений: 36,872
Записей в блоге: 12
28.03.2013, 17:38
Вообще-то у меня написано, какое значение подразумевается под xlExcel8. Неужели так сложно написать:
C++
1
const int xlExcel8 = 56;
?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.03.2013, 17:38
Помогаю со студенческими работами здесь

SaveDialog
Привет всем, возник вопрос! Как можно в SaveDialoge поле ввода имени файла сделать неактивным и выбор фильтра тоже? Заранее большое...

Opendialog и Savedialog
Вообщем работаю с компонентоми Opendialog и Savedialog. Суть задачи, есть форма, с двумя мемо, с двумя этими компонентами и кнопкой...

SaveDialog и 3 vector
Добрый день. В програме есть 3 структуры vector vector <customers> client; vector <order> deal; vector <work> service; ...

SaveDialog и Edit
Всем добрый вечер, и жителям дальнего востока доброе утро!:yes: У меня собственно не самая сложная проблема однако решение не могу...

SaveDialog сразу не сохраняет
Здраствуйте! Проблема следующая: в моей программке рандомно заполняется матрица, ее нужно сохранить в Файл, очистить матрицу и снова...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru