Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на C / C++


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

_Ayl_
Статус: Студент
Рейтинг: 1364
∙ повысить рейтинг »
Boriss
Статус: Академик
Рейтинг: 1047
∙ повысить рейтинг »
Micren
Статус: Бакалавр
Рейтинг: 946
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / C/C++

Номер выпуска:1408
Дата выхода:18.10.2009, 00:30
Администратор рассылки:Dr_Andrew, Модератор
Подписчиков / экспертов:642 / 168
Вопросов / ответов:2 / 2
IRC-канал по теме:#C

Вопрос № 173218: Здравствуйте, уважаемые эксперты Помогите пожалуйста разобраться с ошибкой при работе с OLE. Необходимо открыть уже существующий файл, использовать его как шаблон, и выполнить определенные преобразования над ним. По статьям из интернета наброс...


Вопрос № 173228: Здраствуйте Уважаемые эксперты, Написал програмку под windows, использовал функцию из conio.h kbhit() теперь хочю зделать чтобы програма компилировалась и под linux, но как я понел conio.h в линуксе нету, подскажите как решить эту проблему? т.е. м...

Вопрос № 173218:

Здравствуйте, уважаемые эксперты
Помогите пожалуйста разобраться с ошибкой при работе с OLE. Необходимо открыть уже существующий файл, использовать его как шаблон, и выполнить определенные преобразования над ним.
По статьям из интернета набросал код, приведенный в приложении, но проблема с открытием файла 1.xls, программа почему то его не видит в строке app.OlePropertyGet("Workbooks").OleProcedure("Add","1.xls") и выдает ошибку. Этот файл точно лежит в папке с программой, FileExists("1.xls") это подтверждает... Если прописывать путь в явном виде, например "D:\\1.xls" то все работает. В чем может быть ошибка?
p.s. программа пишется в среде c++ builder 6

Отправлен: 12.10.2009, 19:36
Вопрос задал: Блок Иван/ Blin, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает amnick, 3-й класс :
Здравствуйте, Блок Иван/ Blin.
Насколько я понимаю, проблема в текущих каталогах — они разные для Вашего приложения и Excel. Файл 1.xls находится в текущем каталоге Вашего приложения, поэтому FileExists("1.xls") его находит. А вот для Excel текущий каталог — другой, и поэтому требуется указывать полный путь ("D:\\1.xls"). Мой подход — всегда передавать полный путь, во избежание подобных недоразумений.

Вот цитата от Microsoft (http://www.microsoft.com/Rus/Msdn/Activ/MSVB/Archive/Mixture/FileSystem/165.mspx):
Что такое каталоги Windows и System — в целом понятно. Их имена раз и навсегда жестко фиксируются в момент инициализации Windows. С текущим каталогом дела обстоят посложнее. Это каталог, где содержится запущенное на выполнение приложение. Соответственно, если вы запускаете Tip164.vbp в среде VB, то текущим будет каталог, где находится VB. Если же вы создадите и запустите автономное приложение Tip164.exe, то текущим будет каталог, где ра змещается этот файл.

успехов

Ответ отправил: amnick, 3-й класс
Ответ отправлен: 12.10.2009, 21:23

Оценка ответа: 5
Комментарий к оценке:
спасибо, почему то не подумал,что Excel может использовать другой каталог...решил проблему использованием ф-ии _fullpath из библиотеки stdlib

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 255352 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вопрос № 173228:

    Здраствуйте Уважаемые эксперты,
    Написал програмку под windows, использовал функцию из conio.h kbhit() теперь хочю зделать чтобы програма компилировалась и под linux, но как я понел conio.h в линуксе нету, подскажите как решить эту проблему? т.е. может есть какой-нибуть аналог функции kbhit() под линукс?
    заранее спасибо.

    Отправлен: 12.10.2009, 23:17
    Вопрос задал: Станислав, 2-й класс
    Всего ответов: 1
    Страница вопроса »


    Отвечает vladisslav, 5-й класс :
    Здравствуйте, Станислав.
    Можно проверять наличие данных, доступных для чтения из стандартного ввода, с помощью ioctl FIONREAD
    #include <sys/ioctl.h>
    int kbhit()
    {
    size_t size=0;
    ioctl(stdin,FIONREAD,&size);
    return (size>0);
    };


    Правильный код:

    Код:

    #include <iostream>
    #include <termios.h>
    #include <sys/ioctl.h>
    using namespace std;
    //-----------------------------------------------------
    void ReadKey()
    {
    static const int ciSTDIN = 0;
    static bool bInitialized = false;
    int iSize = 0;

    while(iSize == 0)
    {
    if(!bInitialized)
    {
    termios Terminal;
    tcgetattr(ciSTDIN, & Terminal);
    Terminal.c_lflag &= ~ICANON;
    tcsetattr(ciSTDIN, TCSANOW, & Terminal);
    setbuf(stdin, NULL);
    bInitialized = true;

    }

    ioctl(ciSTDIN, FIONREAD, & iSize);
    }
    };
    //-----------------------------------------------------
    int main()
    {
    cout << "Когда будете готовы, нажмите любую клавишу..." << endl;
    ReadKey();
    cout << " - клавиша была нажата." << endl;
    return 0;
    }
    В Linux Ваш код работать не будет.
    -----
    ∙ Отредактировал: Dr_Andrew, Модератор
    ∙ Дата редактирования: 15.10.2009, 10:40 (время московское)

    Ответ отправил: vladisslav, 5-й класс
    Ответ отправлен: 13.10.2009, 02:49

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 255358 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2009.6.9 от 25.09.2009

    В избранное