Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
5 / 5 / 1
Регистрация: 21.11.2010
Сообщений: 72

Ошибки при экспорте из StringGrid в Excel

24.03.2015, 15:44. Показов 2679. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Попробовал реализовать сохранение данных из СтрингГрид в Ексель, все скомпилировалась, программа пишет данные в xls-файл, но иногда не корректно, т.е. иногда все нормально, иногда у некоторых ячеек слетает формат (см. вложение - т.е. у всех ячеек формат ч:мм:сс, а у одной - "общий").
Так же напрягает не совсем корректное открытие файла Екселем (см. так же вложение - если нажать "Да", то файл открывается).

Код, который пишет данные в файл при нажатиии кнопки (название файла берется из edit-a):

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
function TForm1.GetExcelFileName: String;
begin
  Result := ExtractFilePath(Application.ExeName) + Edit6.Text;
 
  if LowerCase(ExtractFileExt(Result)) <> EXCEL_FILE_EXT then
    Result := Result + EXCEL_FILE_EXT;
end;
 
procedure TForm1.Button2Click(Sender: TObject);
var
 ExcelApp, Sheet: variant;
 Col, Row: Word;
begin
  //*******************
ExcelApp := CreateOleObject('Excel.Application');
  try
    ExcelApp.Visible := false;
 
    ExcelApp.Workbooks.Add;
    Sheet := ExcelApp.ActiveWorkbook.Worksheets[1];
 
    for Col := 0 to StringGrid1.ColCount - 1 do
      for Row := 0 to StringGrid1.RowCount - 1 do
        Sheet.Cells[Row + 1, Col + 1] := StringGrid1.Cells[Col, Row];
 
    ExcelApp.ActiveWorkbook.SaveAs(GetExcelFileName);
 
    ShowMessage('Ok!');
  finally
    ExcelApp.Application.Quit;
    ExcelApp := unassigned;
    Sheet := Unassigned;
  end;
//*******************
end;
В чем может быть проблема? Прошу очень Вашей помощи...
Миниатюры
Ошибки при экспорте из StringGrid в Excel   Ошибки при экспорте из StringGrid в Excel  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.03.2015, 15:44
Ответы с готовыми решениями:

Как выгрузить процесс Excel из памяти при экспорте данных из ASP.Net (C#) в Excel?
Здравствуйте! Как выгрузить процесс Excel из памяти при экспорте данных из ASP.Net (C#) в Excel? Вопрос обсуждается везде и много...

StringGrid, как сохранить цвет при экспорте?
Добрый день! Помогите мне пожалуйста. у меня есть stringgrid закрашиваю его так procedure TForm1.StringGrid1DrawCell(Sender: TObject;...

Иероглифы при экспорте данных из таблицы StringGrid в файл
Пишу программу, выполняющую расчёты по заданным в программе формулам, используя данные, которые загружаются из XML-файлов. На...

11
Эксперт Pascal/Delphi
 Аватар для droider
4925 / 2792 / 856
Регистрация: 04.10.2012
Сообщений: 10,180
24.03.2015, 15:59
Цитата Сообщение от EVG! Посмотреть сообщение
Так же напрягает не совсем корректное открытие файла Екселем
А Вы сохраняйте его нормально, сопоставив с соответствующим расширением.
0
5 / 5 / 1
Регистрация: 21.11.2010
Сообщений: 72
24.03.2015, 17:07  [ТС]
Я сопоставляю...
Извиняюсь, забыл поместить в листинг:

Delphi
1
2
const
  EXCEL_FILE_EXT = '.xls';
Где закралась неточность?

Добавлено через 20 минут
Вот так вроде бы нормально сохраняет:
Delphi
1
Sheet.Cells[Row + 1, Col + 1] := '''' + StringGrid1.Cells[Col, Row];
Но ругается на формат при открытии все равно.
0
Эксперт Pascal/Delphi
 Аватар для droider
4925 / 2792 / 856
Регистрация: 04.10.2012
Сообщений: 10,180
24.03.2015, 17:37
Цитата Сообщение от EVG! Посмотреть сообщение
ругается на формат при открытии все равно
Решение "в лоб":
В меню Пуск пункт Выполнить, введите команду regedit и нажмите кнопку ОК.
Найдите и выделите следующий подраздел реестра:
HKEY_CURRENT_USER\Software\Microsoft\Off ice\<номер версии>\Excel\Security
В меню Правка выберите пункт Создать, а затем — Параметр DWORD.
Введите ExtensionHardening и нажмите клавишу ВВОД.
Щелкните параметр ExtensionHardening правой кнопкой мыши и выберите команду Изменить.
В поле Значение введите значение параметра и нажмите кнопку ОК.

Далее перечислены подходящие значения параметра ExtensionHardening:
0: не проверять расширение имени файла и тип файла, а также обойти функцию предупреждающего сообщения.
1: проверить расширение имени файла и тип файла. Если они не совпадают, отображать предупреждающее сообщение.
2: проверить расширение имени файла и тип файла. Если они не совпадают, не открывать этот файл.
По-простому: добавить в код перед созданием книги
Delphi
1
ExcelApp.DisplayAlerts :=False;
Не катит?
0
Житель Земли
 Аватар для DenNik
3004 / 3025 / 390
Регистрация: 26.07.2011
Сообщений: 11,465
Записей в блоге: 1
24.03.2015, 17:47
Цитата Сообщение от EVG! Посмотреть сообщение
у всех ячеек формат ч:мм:сс, а у одной - "общий").
так ты назначь всем ячейкам формат "общий"
0
Эксперт Pascal/Delphi
 Аватар для droider
4925 / 2792 / 856
Регистрация: 04.10.2012
Сообщений: 10,180
24.03.2015, 17:48
Лучший ответ Сообщение было отмечено EVG! как решение

Решение

И еще попробуйте
Delphi
1
EXCEL_FILE_EXT = '.xlsx'; //для новых версий
0
5 / 5 / 1
Регистрация: 21.11.2010
Сообщений: 72
24.03.2015, 17:56  [ТС]
Цитата Сообщение от droider Посмотреть сообщение
По-простому: добавить в код перед созданием книги
Так - все равно ругается на формат, единственное изменение, теперь если файл уже существует, то не спрашивает перезаписать или нет, сразу перезаписывает.

С реестром - не получится в виду, что программа для проведения наших местных соревнований и будет использоваться на разных . Попросили помочь, пришлось вспоминать делфи)

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

Добавлено через 3 минуты
Цитата Сообщение от droider Посмотреть сообщение
И еще попробуйте
Код Delphi
1
EXCEL_FILE_EXT = '.xlsx'; //для новых версий
Во! Вот так работает и не ругается)) В чем проблема то с классическим разрешением? Была мысль попробовать, но отогнал ее от себя - мол, какая разница.
Спасибо!

Добавлено через 2 минуты
Цитата Сообщение от DenNik Посмотреть сообщение
так ты назначь всем ячейкам формат "общий"
как это сделать средствами делфи?
как писал выше - сделал вот такой костыль (теперь все форматы - общий):
Delphi
1
Sheet.Cells[Row + 1, Col + 1] := '''' + StringGrid1.Cells[Col, Row];
ЗЫ. Я больше сисадмин, потому костыль, а так наверное правильнее - фича))) Извините за оффтоп.
0
Житель Земли
 Аватар для DenNik
3004 / 3025 / 390
Регистрация: 26.07.2011
Сообщений: 11,465
Записей в блоге: 1
24.03.2015, 18:01
EVG!, почитай эту книгу
Название: Программирование документов и приложений MS Office в Delphi
Автор: Василий Корняков
Издательство: БХВ-Петербург
Год: 2005
ISBN: 5-94157-458-4
Добавлено через 1 минуту
еще подсказка. многое можно узнать при помощи макросов. ты записываешь какое-то действи в Экселе макросом. потом смотришь код VBA, его можно легко адаптировать в паскаль, особенно, когда прочитаешь книгу и будешь знать принципы работы с экселем из Делфи
1
5 / 5 / 1
Регистрация: 21.11.2010
Сообщений: 72
24.03.2015, 18:07  [ТС]
Спасибо!
0
Житель Земли
 Аватар для DenNik
3004 / 3025 / 390
Регистрация: 26.07.2011
Сообщений: 11,465
Записей в блоге: 1
24.03.2015, 18:12
вот пример макроса
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Sub Макрос1()
'
' Макрос1 Макрос
'
 
'
    Range("A1").Select
    Selection.Font.Bold = True
    With Selection.Font
        .Color = -16776961
        .TintAndShade = 0
    End With
End Sub
код на делфи
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
procedure TForm1.Button1Click(Sender: TObject);
var
  E: OleVariant;
  Range: OleVariant;
begin
  E:= CreateOleObject('Excel.Application');
  E.WorkBooks.Add;
  Range:= E.ActiveWorkbook.Worksheets[1].Range['A1'];
  Range.Value:= 'Hello';
  Range.Font.Bold:= True;
  Range.Font.Color:= clRed;
  E.Visible:= true;
end;
результат
0
Житель Земли
 Аватар для DenNik
3004 / 3025 / 390
Регистрация: 26.07.2011
Сообщений: 11,465
Записей в блоге: 1
24.03.2015, 18:14
а с большими объемам ячеек удобнее работать через вариантные массивы
0
5 / 5 / 1
Регистрация: 21.11.2010
Сообщений: 72
24.03.2015, 18:18  [ТС]
Сегодня будет интересная ночь) Давно не сидел за делфи, ушел в другую область.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.03.2015, 18:18
Помогаю со студенческими работами здесь

Ошибки при экспорте в swf ролик
Выдает ошибки при компиляции, облазил форумы, так и не разобрался, помогите пожалуйста. Скрин ошибок во вложениях. package { ...

кодировкой при экспорте в Excel
Доброго времени суток всем!!!! Response.ContentType = &quot;text/csv&quot;; Response.AddHeader(&quot;Content-Disposition&quot;, &quot;attachment;...

Названия при экспорте в Excel
Добрый день, может кто подскажет, как разрешить вот такие проблемки: Есть запрос, который нужно экспортировать в Excel. При этом нужно...

Покраска Excel при экспорте
Добрый день, нужно покрасить определенные столбцы в другой цвет, но проблема в том, что он красит не только столбцы, но и все ячейки до...

Ошибка при экспорте в Excel
Здравствуйте! При нажатии на кнопку Excel получаю ошибку: Control 'GridView1' of type 'GridView' must be placed inside a form tag with...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Основы WebGL. Раскрашивание вершин с помощью VBO
8Observer8 05.07.2025
На русском https:/ / vkvideo. ru/ video-231374465_456239020 На английском https:/ / www. youtube. com/ watch?v=oskqtCrWns0 Исходники примера:
Мониторинг микросервисов с OpenTelemetry в Kubernetes
Mr. Docker 04.07.2025
Проблема наблюдаемости (observability) в Kubernetes - это не просто вопрос сбора логов или метрик. Это целый комплекс вызовов, которые возникают из-за самой природы контейнеризации и оркестрации. К. . .
Проблемы с Kotlin и Wasm при создании игры
GameUnited 03.07.2025
В современном мире разработки игр выбор технологии - это зачастую балансирование между удобством разработки, переносимостью и производительностью. Когда я решил создать свою первую веб-игру, мой. . .
Создаем микросервисы с Go и Kubernetes
golander 02.07.2025
Когда я только начинал с микросервисами, все спорили о том, какой язык юзать. Сейчас Go (или Golang) фактически захватил эту нишу. И вот почему этот язык настолько заходит для этих задач: . . .
C++23, квантовые вычисления и взаимодействие с Q#
bytestream 02.07.2025
Я всегда с некоторым скептицизмом относился к громким заявлениям о революциях в IT, но квантовые вычисления - это тот случай, когда революция действительно происходит прямо у нас на глазах. Последние. . .
Вот в чем сила LM.
Hrethgir 02.07.2025
как на английском будет “обслуживание“ Слово «обслуживание» на английском языке может переводиться несколькими способами в зависимости от контекста: * **Service** — самый распространённый. . .
Использование Keycloak со Spring Boot и интеграция Identity Provider
Javaican 01.07.2025
Два года назад я получил задачу, которая сначала показалась тривиальной: интегрировать корпоративную аутентификацию в микросервисную архитектуру. На тот момент у нас было семь Spring Boot приложений,. . .
Содержание темы с примерами на WebGL
8Observer8 01.07.2025
Все примеры из книги Мацуды и Ли в песочнице JSFiddle Пример выводит точку красного цвета размером 10 пикселей на WebGL 1. 0 и 2. 0 WebGL 1. 0. Передача координаты точки из главной программы в. . .
Основы WebGL. Простой треугольник
8Observer8 01.07.2025
Простой треугольник без трансформаций. Для трансформаций можно использовать glMatrix, как в примере: https:/ / plnkr. co/ edit/ qT6ZTwvncLPRamK5?preview На русском: . . .
Полиглотные микросервисы на C# и .NET
ArchitectMsa 30.06.2025
Полиглотная архитектура появилась не из желания усложнить жизнь разработчикам. Она родилась из практической необходимости решать разные задачи наиболее эффективным способом. В одном из проектов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru