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

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

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

Author24 — интернет-сервис помощи студентам
Попробовал реализовать сохранение данных из СтрингГрид в Ексель, все скомпилировалась, программа пишет данные в 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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.03.2015, 15:44
Ответы с готовыми решениями:

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

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

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

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

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

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

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

Далее перечислены подходящие значения параметра ExtensionHardening:
0: не проверять расширение имени файла и тип файла, а также обойти функцию предупреждающего сообщения.
1: проверить расширение имени файла и тип файла. Если они не совпадают, отображать предупреждающее сообщение.
2: проверить расширение имени файла и тип файла. Если они не совпадают, не открывать этот файл.
По-простому: добавить в код перед созданием книги
Delphi
1
ExcelApp.DisplayAlerts :=False;
Не катит?
0
Житель Земли
3003 / 3005 / 391
Регистрация: 26.07.2011
Сообщений: 11,464
Записей в блоге: 1
24.03.2015, 17:47 5
Цитата Сообщение от EVG! Посмотреть сообщение
у всех ячеек формат ч:мм:сс, а у одной - "общий").
так ты назначь всем ячейкам формат "общий"
0
Эксперт Pascal/Delphi
4913 / 2782 / 853
Регистрация: 04.10.2012
Сообщений: 10,127
24.03.2015, 17:48 6
Лучший ответ Сообщение было отмечено EVG! как решение

Решение

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

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

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

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

Добавлено через 2 минуты
Цитата Сообщение от DenNik Посмотреть сообщение
так ты назначь всем ячейкам формат "общий"
как это сделать средствами делфи?
как писал выше - сделал вот такой костыль (теперь все форматы - общий):
Delphi
1
Sheet.Cells[Row + 1, Col + 1] := '''' + StringGrid1.Cells[Col, Row];
ЗЫ. Я больше сисадмин, потому костыль, а так наверное правильнее - фича))) Извините за оффтоп.
0
Житель Земли
3003 / 3005 / 391
Регистрация: 26.07.2011
Сообщений: 11,464
Записей в блоге: 1
24.03.2015, 18:01 8
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  [ТС] 9
Спасибо!
0
Житель Земли
3003 / 3005 / 391
Регистрация: 26.07.2011
Сообщений: 11,464
Записей в блоге: 1
24.03.2015, 18:12 10
вот пример макроса
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;
результат
Ошибки при экспорте из StringGrid в Excel
0
Житель Земли
3003 / 3005 / 391
Регистрация: 26.07.2011
Сообщений: 11,464
Записей в блоге: 1
24.03.2015, 18:14 11
а с большими объемам ячеек удобнее работать через вариантные массивы
0
5 / 5 / 1
Регистрация: 21.11.2010
Сообщений: 72
24.03.2015, 18:18  [ТС] 12
Сегодня будет интересная ночь) Давно не сидел за делфи, ушел в другую область.
0
24.03.2015, 18:18
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
24.03.2015, 18:18
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru