Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Ole+Excel (и не только), ошибка при использовании != 
V
    Опции темы
Deft
  Дата 26.5.2009, 05:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 22
Регистрация: 19.6.2008
Где: Хабаровск

Репутация: нет
Всего: нет



в общем мне надо проверить что ячейка не пуста
Код

...
AnsiString val="";
if (Sheet.OlePropertyGet("Cells",i,j)!=val)
...

(пробовал и "><" писать вместо !=)
при работе вылетает с ошибкой "Invalid Variant Operation".
при этом сравнение на равенство "==" работает без проблем...
как победить?

решилось простым переприсвоением AnsiString a=Sheet.OlePropertyGet("Cells",i,j); и последующем сравнение уже переменной a.. но с "!=" однако не понятная затупа..

Это сообщение отредактировал(а) Deft - 26.5.2009, 06:28
PM MAIL ICQ   Вверх
Usper
Дата 26.5.2009, 08:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 325
Регистрация: 13.4.2007

Репутация: 15
Всего: 15



Вообще говоря из кода не понятно, что такое Sheet, но, как мне кажется, Вы не правильно получаете значение ячейки. Значение ячейки лежит в свойстве "Value" объекта "Cell", который в свою очередь является свойством объекта "Cells".
Так же надо аккуратнее сравнивать значение типа Variant, которое возвращается OlePropertyGet(), с AnsiString`ом. Совсем не обязательно, что такое сравнение допустимо, на что компилятор и указал.


--------------------
На посохе волшебном нехилый набалдашник, большой такой, огромный, нехилый набалдашник.
PM MAIL   Вверх
Deft
Дата 26.5.2009, 08:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 22
Регистрация: 19.6.2008
Где: Хабаровск

Репутация: нет
Всего: нет



ок, чтоб было понятно ( не вставил в первый пост потому что дело не в этом)
Код

Book=Excel.OlePropertyGet("Workbooks").OlePropertyGet("Open", fPath.c_str());
Sheet=Book.OlePropertyGet("Worksheets", i);

насчет обращения к ячейке: есть несколько способов. и как у меня и через value, не важно, записать значение в ячейку обратившись к ней таким способом я могу.
насчет аккуратнее сравнивать. почему тогда "==" не вызывает ошибки? в общем не важно, для себя я проблему эту решил.
PM MAIL ICQ   Вверх
MDamien
Дата 2.12.2010, 20:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 2
Регистрация: 23.9.2010

Репутация: нет
Всего: нет



Понимаю, что давно не актуально, но всё же =)
Думаю так сработает правильно:
Код

...
AnsiString val="";
if (Sheet.OlePropertyGet("Cells",i,j).OlePropertyGet("Value")!=val)
...


PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++ Builder"
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по С++ Builder обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Настоятельно рекомендуем заглянуть в DRKB (Delphi Russian Knowledge Base) - крупнейший в рунете сборник материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Rrader.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C++ Builder | Следующая тема »


 




[ Время генерации скрипта: 0.0814 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.