|
|
#1
|
|||
|
|||
UNICODE
Народ, очень нужна помощь.
Ситуация: Есть файл .csv, метод разделения колонок - табуляция. Первые два символа в файле(если читать в ASCII) - 255 и 254, в блокноте они (эти 2 символа) не отображаются, перед каждым последующим символом есть или #0 или #4. Я думаю это Юникод. Но вот дилема: Нужно перекинуть этот файл скажем в стринг_грид, а прочитать его не могу Скажите, возможно ли прочитать его без установки ТНТ компонентов, а если нет, то подскажите де их взять и как правильно установить... Пы.Сы. пользуюсь 6 делфи. |
#2
|
||||
|
||||
Без компонентов можно сделать абсолютно все - главное была бы голова на плечах и свободное время =)
А файл можно сначала избавить от #0 и #4 путем протой замены символов. Читай посимвольно файл и делай проверку: если байт - #0 или #4, то пропускаем, иначе - добавляем символ в переменную типа String (ток не забудь, что #0 в конце файла - это нормально =)). Конечно, если файл будет большим, этот алго будет работать медленно, но его можно хорошо оптимизировать. И возможно, можно прочесть весь файл в переменную типа String а потом банальным StringReplace заменить все что нужно, но есть сомнения по этому поводу, т.к. #0 в переменной типа String может оказаться граблями, сам не помню, что в этом случае будет, а проверить не могу - ща под рукой нету Делфи. THE CRACKER IS OUT THERE |
#3
|
||||
|
||||
А может просто воспользоваться функцией WideCharToString
|
#4
|
|||
|
|||
4kusNick, пробовал....
Дело в том, что коды остальных символов лежат в интервале примерно от 0 до 100, а большинство до 32... как только убираю 0 и 4 остаются только квадратики... Вайд_Чар_Ту_Стринг тоже пробовал, мало помогает.... |