Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / C++ [игнор отключен] [закрыт для гостей] / заполнение вариантного массива / 2 сообщений из 2, страница 1 из 1
06.01.2007, 21:46
    #34239726
londinium
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
заполнение вариантного массива
Здравствуйте, Господа!

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

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
IBQuery1->FetchAll();
int iRecordCount=IBQuery1->RecordCount;
int iFieldCount=IBQuery1->FieldCount;

int iBounds[ 2 ]={iFieldCount,iRecordCount};
Variant vDataArray=VarArrayCreate(iBounds, 1 ,varVariant);

Здесь все прошло нормально.

Но при попытке заполнить массив vDataArray данными
Код: plaintext
vDataArray.PutElement("i+j", 1 , 1 );
С++Builder ругается как прапорщик. «Variant array index are out of bounds”.

Во всех смотренных примерах в массиве iBounds стоят конкретные элементы(например, 2,6,7), но в моем случае это не пойдет, т.к. SQL-запрос может вернуть разное количество записей и столбцов.

Вопрос: как мне правильно записать данные из IBQuery в вариантный массив.

С уважением, Londinium.
...
Рейтинг: 0 / 0
06.01.2007, 23:58
    #34239838
Тынц.
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
заполнение вариантного массива
F1The Bounds parameter must contain an even number of values, where each pair of values specifies the upper and lower bounds of one dimension of the array.

То есть для 2-х мерного массива в Bounds должно быть 2 пары значений.

Код: plaintext
1.
2.
3.
4.
int iBounds[ 4 ]={ 0 ,iFieldCount, 0 ,iRecordCount};
// или так, смотря как используешь
// int iBounds[4]={0,iRecordCount,0,iFieldCount};
Variant vDataArray=VarArrayCreate(iBounds, 3 ,varVariant);
...
Рейтинг: 0 / 0
Форумы / C++ [игнор отключен] [закрыт для гостей] / заполнение вариантного массива / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]