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

ф-я в vba для конверт. из dos to windows?

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





СообщениеДобавлено: Вт Июл 02 2002 11:42    Заголовок сообщения: ф-я в vba для конверт. из dos to windows? Ответить с цитатой

Помогите, пожалуйста!
Есть определенным образом структурированный DOS-файл. Нужно определенные данные из него занести в соответствующие ячейки Excel-документа. ( - макрос)
Все хорошо, кроме кодировки. Есть ли функция в vba, которая позволяет перевести строку из одной кодировки в другую? или как можно подключить функцию, написанную на Си,которая решает проблему перекодировки?
Заранее спасибо!
Вернуться к началу
Adil
Гость





СообщениеДобавлено: Ср Июл 03 2002 10:38    Заголовок сообщения: Re: ф-я в vba для конверт. из dos to windows? Ответить с цитатой

Про VBA не знаю, а вот функции написанные на С
(угловые скобки заменены буквами, т.к. на этом форуме с ними какие-то траблы)

//----------------------------
unsigned char* Decode_Win_to_DOS(unsigned char * str)
{
unsigned char ch;
short i=0;
do
{
ch=str[i];
if(ch _GE_ 128)
{
if(ch _GE_ 192&& ch _LE_ 239)
{
ch-=(unsigned char)192;
ch+=(unsigned char)128;
}
else if(ch _GE_ 240)
{
ch-=(unsigned char)240;
ch+=(unsigned char)224;
}
else if(ch==(unsigned char )'№')
ch=252;
else
ch=32;
str[i]=ch;
}
i++;
}while(ch!=0);
return str;
}
//--------------
unsigned char* Decode_DOS_to_Win(unsigned char * str)
{
unsigned char ch;
short i=0;
do
{
ch=str[i];
if(ch _GE_ 128)
{
if(ch _LE_ 175)
{
ch-=(unsigned char)128;
ch+=(unsigned char)192;
}
else if(ch _GE_ 224&&ch _LE_ 239)
{
ch-=(unsigned char)224;
ch+=(unsigned char)240;
}
else if(ch==252)
ch='№';
else
ch=32;
str[i]=ch;
}
i++;
}while(ch!=0);
return str;
}
//-------------------------
На ВБ переведи уж сам.

Удачи.
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...