Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

ковыряние в word, excel документах

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Vasiaofcose
Гость





СообщениеДобавлено: Вт Май 06 2003 06:06    Заголовок сообщения: ковыряние в word, excel документах Ответить с цитатой

Стоит простая но не простая задача - имеется файл doc(word) содержащий заголовок - простой абзац, и таблицу, затем подвал.
Вопрос : какими программными средствами(не копаясь в формате doc файла) можно обратиться к word'у как к серверу, чтобы он выдавал содержимое ячейки таблицы.
P.S. сейчсас это делаю сохраняя файл в текст и там уже его потрошу, но,при этом, теряются некоторые символы.
Вернуться к началу
Борис
Гость





СообщениеДобавлено: Вт Май 06 2003 08:24    Заголовок сообщения: Re: ковыряние в word, excel документах Ответить с цитатой

В MSDN (MSDN Library Visual Studio 6.0 и более поздних):
--------------------
Custom OLE Servers
Calvin Hsia
Microsoft Corporation

October 1996
--------------------

А свойства word/excel-документов в их справках.
Вернуться к началу
Anatoliy



Зарегистрирован: 15.04.2002
Сообщения: 681
Откуда: Moscow

СообщениеДобавлено: Вт Май 06 2003 10:45    Заголовок сообщения: грубо вырезал у себя из проги (+) Ответить с цитатой

void TFDocum::TextDoc(AnsiString FText)
{
/*
Variant my_doc;
Variant my_word_app;
Variant my_range;
ShellExecute(Handle, "Open", FText.c_str(), NULL, NULL, SW_SHOWDEFAULT);

Variant this_doc2;
Variant my_docs2;
Variant my_word2 = Variant::GetActiveObject("word.application");
my_docs2 = my_word2.OlePropertyGet("Documents");
this_doc2 = my_docs2.OleFunction("Open",
(Variant)FText.c_str());

try {
my_word_app = Variant::GetActiveObject("word.application"); }
catch(...)
{ ShowMessage("Please open word and load a document and retry");
return; }
my_doc = my_word_app.OlePropertyGet("ActiveDocument");
my_range = my_doc.OleFunction("Range");
my_range = my_doc.OleFunction("Range",(Variant)0,Variant(253));
DM-Tdocum-Edit();
DM-Tdocum-FieldValues["prim"] = my_range = my_doc.OleFunction("Range",(Variant)0,Variant(253));
DM->Tdocum-Post();
my_word_app = my_doc.OleFunction("Close",(Variant)"FText.c_str()");
PostMessage(FindWindow(NULL,"Microsoft Word"), WM_QUIT, 0, 0);
*/
Variant my_doc;
Variant my_word_app;
Variant my_range;
OleVariant files1;
files1 = FText;

Screen->Cursor = crHourGlass;

WordDocument1-ConnectTo(WordApplication1-Documents-Open(file s1)); try { my_word_app = Variant::GetActiveObject("word.application"); }
catch(...)
{ ShowMessage("Нет активных документов. Экспорт не выполнен.");
return; }

my_doc = my_word_app.OlePropertyGet("ActiveDocument");
my_range = my_doc.OleFunction("Range");
my_range = my_doc.OleFunction("Range",(Variant)0,Variant(253));
DM-Tdocum-Edit();
DM-Tdocum-FieldValues["prim"] = my_range = my_doc.OleFunction("Range",(Variant)0,Variant(253));


Идея такова, что тебе нужно открыть документ и в нем через функции читать коллекцию из которой и выгружать нужные данные. Я с таблицами в ворде не работал, я сразу с текстом.

P.S.
Напиши на почту, вышлю примерчики по работе с вордом в с++В, если нужно.

Разберешся с таблицой в ворде,и будет время кинь мне как, если не трудно.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...