Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2003.02.10;
Скачать: [xml.tar.bz2];

Вниз

из Delphi в Excel   Найти похожие ветки 

 
olookin   (2003-01-31 17:35) [0]

Здравствуйте.
Как передать из Делфи в Эксел строку с русскими символами?

Заранее спасибо.


 
ef2000   (2003-01-31 17:39) [1]

так же как с латинскими или что-то не так?


 
olookin   (2003-01-31 18:07) [2]

to ef2000 нет не так абсолютно. Не передается.


 
Chubais   (2003-01-31 18:46) [3]


> Не передается.

как это понимать? чо - совсем ничо не передается?


 
Cr@sh   (2003-01-31 21:07) [4]

procedure TForm1.BitBtnToExcelOnClick(Sender: TObject);
var
WorkBk : _WorkBook; // определяем WorkBook
WorkSheet : _WorkSheet; // определяем WorkSheet
I, J, K, R, C : Integer;
IIndex : OleVariant;
TabGrid : Variant;
begin
if GenericStringGrid.Cells[0,1] <> "" then
begin
IIndex := 1;
R := GenericStringGrid.RowCount;
C := GenericStringGrid.ColCount;
// Создаём массив-матрицу
TabGrid := VarArrayCreate([0,(R - 1),0,(C - 1)],VarOleStr);
I := 0;
// Определяем цикл для заполнения массива-матрицы
repeat
for J := 0 to (C - 1) do
TabGrid[I,J] := GenericStringGrid.Cells[J,I];
Inc(I,1);
until
I > (R - 1);

// Соединяемся с сервером TExcelApplication
XLApp.Connect;
// Добавляем WorkBooks в ExcelApplication
XLApp.WorkBooks.Add(xlWBatWorkSheet,0);
// Выбираем первую WorkBook
WorkBk := XLApp.WorkBooks.Item[IIndex];
// Определяем первый WorkSheet
WorkSheet := WorkBk.WorkSheets.Get_Item(1) as _WorkSheet;
// Сопоставляем Delphi массив-матрицу с матрицей в WorkSheet
Worksheet.Range["A1",Worksheet.Cells.Item[R,C]].Value := TabGrid;
// Заполняем свойства WorkSheet
WorkSheet.Name := "Customers";
Worksheet.Columns.Font.Bold := True;
Worksheet.Columns.HorizontalAlignment := xlRight;
WorkSheet.Columns.ColumnWidth := 14;
// Заполняем всю первую колонку
WorkSheet.Range["A" + IntToStr(1),"A" + IntToStr(R)].Font.Color := clBlue;
WorkSheet.Range["A" + IntToStr(1),"A" + IntToStr(R)].HorizontalAlignment := xlHAlignLeft;
WorkSheet.Range["A" + IntToStr(1),"A" + IntToStr(R)].ColumnWidth := 31;
// Показываем Excel
XLApp.Visible[0] := True;
// Разрываем связь с сервером
XLApp.Disconnect;
// Unassign the Delphi Variant Matrix
TabGrid := Unassigned;
end;
end;


 
olookin   (2003-02-01 12:39) [5]

to Crash/
Спасибо за развернутый пример, но я уже реализовал взаимодействие с Excel.

Для всех...

Я ошибался, считая что русские символы вообще не передаются. Они передаются (как и все остальные), но в количестве не более чем 255 символов в строке. У меня же строка содержит 2048 символов. В итоге при передаче длинной строки в TextFrame она то ли обрезается, то ли еще что то. В общем, в отличие от коротких, длинная строка не отображается в TextFrame. Как быть? Заранее спасибо.


 
olookin   (2003-02-01 13:55) [6]

Пожалуйста, ответьте.... Кто знает ответ, конечно


 
Tux   (2003-02-01 14:37) [7]

Млин... WideString ом строки передавай, юникод ведь как-никак...


 
olookin   (2003-02-01 14:55) [8]

To TUX

не помогает я уже пробовал. Похоже в Excel либо другая кодировка либо еще что то



Страницы: 1 вся ветка

Форум: "Основная";
Текущий архив: 2003.02.10;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.46 MB
Время: 0.01 c
14-29103
petr_v_a
2003-01-24 17:52
2003.02.10
Маркировка товара на складах


4-29164
BlackSun
2002-12-29 00:34
2003.02.10
Обращение к винту


1-28828
158963
2003-02-02 17:44
2003.02.10
I need help. please


3-28680
T{}r(l-l
2003-01-24 15:10
2003.02.10
Вызов DTS-пэкаджа из Delphi?


7-29124
maxim2
2002-12-05 21:49
2003.02.10
Как реализовать такую штуку на Delphi





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский