|
![]() |
#1 |
Участник
|
Угу, насчет .NET согласен.
Вот так можно без промежуточных файлов работать с UTF8 X++: { System.Text.UTF8Encoding UTF8Encoding; System.Byte[] bytes; System.Byte[] utf8; int i; int len; int val; Binary bin; ; UTF8Encoding = new System.Text.UTF8Encoding(); bytes = UTF8Encoding.GetBytes("Строка UTF8"); len = bytes.get_Length(); bin = new Binary(len); for (i=0;i<len;i++) { val = bytes.GetValue(i); bin.byte(i, val); } info(bin.string(0)); utf8 = new System.Byte[len](); for (i=0;i<len;i++) utf8.SetValue(System.Convert::ToByte(bin.byte(i)), i); info(UTF8Encoding.GetString(utf8)); }
__________________
Axapta v.3.0 sp5 kr2 |
|
|
За это сообщение автора поблагодарили: Logger (5), Sergey Petrov (1). |
![]() |
#2 |
Боец
|
Ещё простой вариант:
X++: TextBuffer textBuffer; ; textBuffer = new TextBuffer(); textBuffer.setText("Строка"); textBuffer.toFile(@"C:\utf8.txt", FileEncoding::UTF8); |
|
![]() |
#3 |
Участник
|
Цитата:
Попробовал применить такой подход для строчек - не получилось ![]() В чем может быть проблема ? Изначально задача стояла переписать на .Net функции X++: client static str oem2CharBuff(str strSource) { DLL winApiDLL = new DLL( #UserDLL ); DLLFunction oemToCharBuff = new DLLFunction( winApiDLL, @'OemToCharBuffA'); Binary bSource = new Binary( strSource ); str ret; ; oemToCharBuff.returns( ExtTypes::DWORD ); oemToCharBuff.arg( ExtTypes::POINTER, ExtTypes::POINTER, ExtTypes::DWord ); oemToCharBuff.call( bSource, bSource, strlen(strSource) ); ret = bSource.string(0); return ret; } X++: client static str char2OEM(str strSource) { DLL _winApiDLL = new DLL('USER32'); DLLFunction _CharToOEM = new DLLFunction(_winApiDLL, 'CharToOemA'); Binary bSource = new Binary(strSource); str oemstr; ; _CharToOEM.returns(ExtTypes:: DWORD); _CharToOEM.arg(ExtTypes::POINTER, ExtTypes::POINTER); _CharToOEM.call(bSource, bSource); oemstr = bSource.string(0); return oemstr; } X++: client static str oem2Char(str strSource) { DLL _winApiDLL = new DLL('USER32'); DLLFunction _CharToOEM = new DLLFunction(_winApiDLL, 'OemToCharA'); Binary bSource = new Binary(strSource); str winstr; ; _CharToOEM.returns(ExtTypes:: DWORD); _CharToOEM.arg(ExtTypes::POINTER, ExtTypes::POINTER); _CharToOEM.call(bSource, bSource); winstr = bSource.string(0); return winstr; } Попробовал вот так : X++: static void Unicode2ANSI_5(Args _args) { // str unicodeStr; System.Text.Encoding encAnsi; System.Byte[] bytesAnsi; System.Byte byte; str byteStr; Counter len; Counter n; asciiio file = SysDataIntegration::openFile(@"c:\_\ttt.txt", "R", ";"); container con; System.Text.Encoding encoding; System.Text.Encoding encoding866; System.Text.Encoding encodingUTF; System.Text.Encoding encodingAnsi; System.Byte[] tmp; System.String ss; str s; str ret; ; New InteropPermission(InteropKind::ClrInterop).assert(); while (file.status() == IO_Status::Ok) { con = file.read(); s = conPeek(con,1); ss = s; //encodingUTF = System.Text.Encoding::get_Unicode(); encodingUTF = System.Text.Encoding::get_UTF8(); encoding866 = System.Text.Encoding::GetEncoding(866); //encoding866 = System.Text.Encoding::get_ASCII(); tmp = encoding866.GetBytes(ss); tmp = System.Text.Encoding::Convert(encoding866, encodingUTF, tmp); ret = encodingUTF.GetString(tmp); info(strFMT("%1 <---> %2 <---> %3 ", conPeek(con,1), winapi::oem2CharBuff( conPeek(con,1) ), ret )); break; } } В файле лежит строка Цитата:
1. Кодировка
Цитата:
1. Љ®¤Ёа®ўЄ
Цитата:
1. Кодировка
Цитата:
1. Љ®¤Ёа®ўЄ
Процитированный джобик вывел что-то типа Цитата:
4. Љ®¤Ёа®ўЄ <---> 4. Кодировка <---> 4. ?R¤ЁаRўЄ
Последний раз редактировалось Logger; 17.12.2013 в 03:11. |
|