Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 2 627

/ вопрос открыт /

Здравствуйте, эксперты!
Сохраняю данные из StringGrid в файл xls. Проблема в том, что числовые данные из моей программы в Excel оказываются в текстовом формате. Это, конечно, исправляется в самом Excel, но хотелось бы чтобы числа сохранялисьв чиловом формате, а текст - в текстовом. Подскажите?

И еще, в StringGrid у меня есть строки с выделенным цветом текстом и при сохранении в xls это выделение не сохраняется. А как сделать чтоб сохранялось?

anbaresi Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задал: anbaresi (статус: Посетитель)
Вопрос отправлен: 13 апреля 2009, 15:06
Состояние вопроса: открыт, ответов: 1.

Ответ #1. Отвечает эксперт: Шичко Игорь

Здравствуйте, anbaresi!
В этой ситуации логично устанавливать программно формат ячейки Excel.
примерно так:
WorkBook.Sheets['Лист'].Range.NumberFormat:= '[$$-409]# ##0,00;'; // доллары
WorkBook.Sheets['Лист'].Range.NumberFormat:= '[$ˆ-2] # ##0,00'; // евро
WorkBook.Sheets['Лист'].Range.NumberFormat:= '# ##0,00p.;-# ##0,00p.'; // рубли
WorkBook.Sheets['Лист'].Range.NumberFormat = '#,##0.00'; // числовой с двумя знаками
WorkBook.Sheets['Лист'].Range.NumberFormat = '@'; // текстовый

Ответ отправил: Шичко Игорь (статус: 9-ый класс)
Время отправки: 13 апреля 2009, 15:33
Оценка за ответ: 4


Мини-форум вопроса

Всего сообщений: 9; последнее сообщение — 6 ноября 2009, 02:18; участников в обсуждении: 4.
anbaresi

anbaresi (статус: Посетитель), 14 апреля 2009, 11:21 [#1]:

А не работает чего-то. Вот и код есть

function saveasexcelfile(stringgrid: tstringgrid; filename: string): boolean;
const xlwbatworksheet = -4167;
var row, col: integer;
gridprevfile: string;
xlapp, sheet: olevariant;
begin
result := false;
xlapp := createoleobject('excel.application');
try
xlapp.visible := false;
xlapp.workbooks.add(xlwbatworksheet);
sheet := xlapp.workbooks[1].worksheets[1];
sheet.name := 'Лист1';
sheet[1].Range.NumberFormat := '#,##0.00';// при добавлении этой строки возникает ошибка EVariantInvalidArgError with Message 'Invalid argument'
for col := 0 to stringgrid.colcount - 1 do
for row := 0 to stringgrid.rowcount - 1 do
sheet.cells[row + 1, col + 1] := stringgrid.cells[col, row];
try
xlapp.workbooks[1].saveas(filename);
result := true;
except
ShowMessage ('Файл не сохранен.');
end;
finally
if not varisempty(xlapp) then
begin
xlapp.displayalerts := false;
xlapp.quit;
xlapp := unassigned;
sheet := unassigned;
end;
end;
end;


procedure TForm1.BitBtn3Click(Sender: TObject);
begin
if(SaveDialog1.Execute) then
begin
if saveasexcelfile(stringgrid1, SaveDialog1.FileName) then
showmessage('Файл сохранен.');
end;
end;


и про цвет не ясно
Шичко Игорь

Шичко Игорь (статус: 9-ый класс), 14 апреля 2009, 11:33 [#2]:

sheet[1].Range['A1'].NumberFormat := '#,##0.00'; // адрес диапазона
или
sheet[1].Range['A1:B5'].NumberFormat := '#,##0.00';

Писал быстро, забыл, бывает
Шичко Игорь

Шичко Игорь (статус: 9-ый класс), 14 апреля 2009, 11:34 [#3]:

Что именно неясно про цвет?
anbaresi

anbaresi (статус: Посетитель), 14 апреля 2009, 20:10 [#4]:

Строки у меня StringGrid имеют разные цвета, но при сохранении в файл xls информация о цвете теряется и все строки (при открытии сохраненного файла в Excel) одного цвета. Как сделать чтоб они и в Excel были выделены цветом?
Шичко Игорь

Шичко Игорь (статус: 9-ый класс), 15 апреля 2009, 09:59 [#5]:

Устанавливайте заливку ячейки соответствующим цветом:
sheet[1].Range['A1'].Interior.ColorIndex:= 15; // 15 код цвета
anbaresi

anbaresi (статус: Посетитель), 15 апреля 2009, 19:06 [#6]:

Т.е. я так понял, что при сохранени мне надо как-то определить какого цвета у меня ячейка в StrigGrid и такой же цвет установить и для ячейки Excel?
Как же тогда определить на этапе сохранения (код функции выше) какого цвета текст в ячейке? Да еще и надо знать какая ячейка Excel соответствует текущей ячейке StringGrid. Пока это мне представляется сложноватым, а других вариантов нет?
Шичко Игорь

Шичко Игорь (статус: 9-ый класс), 16 апреля 2009, 07:38 [#7]:

Вы пишете: "Строки у меня StringGrid имеют разные цвета". Но ведь у Вас есть процедура установки цвета для строки StringGrid. Можно создать массив соответствий номера строки и цвета закраски. А потом определять цвет закраски при перегонке информации в Excel.
sharos

sharos (статус: Посетитель), 5 ноября 2009, 23:13 [#8]:

Приветсвую господа!
У меня вопрос - импортирую таблицу в эксель, сохраняю в файл - XLApp.Workbooks[1].SaveAs(AFileName);
ПРограмма каждый раз спрашивает - такой файл есть, перезаписать и пр. Можно ли как то сделать чтобы сохранял не спрашивая?
Заранее благодарен!
Вадим К

Вадим К (статус: Академик), 6 ноября 2009, 02:18 [#9]:

А может просто перед сохранением удалять файл?
Галочка "подтверждения прочтения" - вселенское зло.

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:33
Выполнено за 0.03 сек.