На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
! user posted image
Пожалуйста, выделяйте текст программы тегом [сode=pas] ... [/сode]. Для этого используйте кнопку [code=pas] в форме ответа или комбобокс, если нужно вставить код на языке, отличном от Дельфи/Паскаля.

Соблюдайте общие правила форума

Следующие вопросы задаются очень часто, подробно разобраны в FAQ и, поэтому, будут безжалостно удаляться:
1. Преобразовать переменную типа String в тип PChar (PAnsiChar)
2. Как "свернуть" программу в трей.
3. Как "скрыться" от Ctrl + Alt + Del (заблокировать их и т.п.)
4. Как запустить программу/файл? (и дождаться ее завершения)
5. Как перехватить API-функции, поставить hook? (перехват сообщений от мыши, клавиатуры - внедрение в удаленное адресное прстранство)
... (продолжение следует) ...

Внимание:
Попытки открытия обсуждений реализации вредоносного ПО, включая различные интерпретации спам-ботов, наказывается предупреждением на 30 дней.
Повторная попытка - 60 дней. Последующие попытки - бан.
Мат в разделе - бан на три месяца...

Полезные ссылки:
user posted image MSDN Library user posted image FAQ раздела user posted image Поиск по разделу user posted image Как правильно задавать вопросы


Выразить свое отношение к модераторам раздела можно здесь: user posted image Rouse_, user posted image Krid

Модераторы: Rouse_, Krid
  
> DELPHI.EXCEL.необычная задача программы , Поиск ячейки с по определенному слову в "комментарии" и опре
    Всем доброго времени суток ;)

    Есть такая задача:
    Нужно программным способом организовать поиск в ячейках excel документа на наличие "коментария".
    Если ячейка с "комментарием" найдена, то:
    a) получить текст "комментария";
    b) получить координаты ячейки;

    Прошу помогите, очень наболевший вопрос.
    Заранее бесконечно благодарен ;)
      Если умеешь работать с Excel через OLE-автоматизацию, то запиши в Excele макрос, проделав при этом поиск вручную, через Ctrl-F. Исходный текст этого макроса повтори в Delphi-программе. Плюс см. хелп по Visual Basic for Applications (вроде так), эта справка по умолчанию вместе с MS Office не ставится, но можно доустановить.
        Макросы буду исключать... Вы как то писали:
        Цитата
        У меня была задача, для решения которой написал макросы в Excel. Позже обнаружилось, что антивирусы (в моем случае Kaspersky) могут блокировать выполнение макросов. Сначала долго удивлялся, почему не работает :). Также Windows XP прибивала Excel при исполнении макроса, если была включена защита DEP (Data Execution Protection).


        Вообщем случилось мне на это попасть... :'(
        Топик: CheckBox в MS-Word

        Спасибо за участие, проблему решил =)

        ExpandedWrap disabled
          procedure TForm1.Button2Click(Sender: TObject);
               type ExcelVars_=Record
                               Comm_Count_       : Integer; // кол-во комментариев в ячейках;
                               pos_comment_String: String;  // сохраняем содержимое комм. ячейки;
                               pos_comment_positN: String;  // сохраняем позицию;
                               end; // type
           
                var Excel    : Variant;
                    MainData_: ExcelVars_;
              begin Excel := CreateOleObject('Excel.Application.9');
                    Excel .  Application.EnableEvents:= false;
                    Excel .  Visible := True;
                    Excel .  Workbooks.Open('x:\мои документы\книга1.xls');
           
                    MainData_.Comm_Count_:=Excel.ActiveSheet.Comments.Count;
                    MainData_.pos_comment_String:=Excel.ActiveSheet.Comments[MainData_.Comm_Count_].text;
                    MainData_.pos_comment_positN:=Excel.ActiveSheet.Comments[MainData_.Comm_Count_].parent.address;
           
                    Memo1.Lines.Add('  Кол-во комментов на листе: '+IntToStr(MainData_.Comm_Count_));
                    Memo1.Lines.Add('  Текст последнего коммента: '+MainData_.pos_comment_String);
                    Memo1.Lines.Add('Позиция последнего коммента: '+MainData_.pos_comment_positN);
           
                    end; // procedure
        Сообщение отредактировано: ERrorMAKros -
        0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
        0 пользователей:


        Рейтинг@Mail.ru
        [ Script execution time: 0,1320 ]   [ 16 queries used ]   [ Generated: 18.08.25, 02:16 GMT ]