А английскую ищет. Полагаю что-то с кодировкой. Но как исправить это?
procedure TfrmMain.btnOpenFileClick(Sender: TObject);
var
f: TextFile;
lineCount: integer;
c: Char;
begin
AssignFile(f, 'test.txt');
Reset(f);
lineCount := 0;
while not Eof(f) do
begin
Read(f, c);
if c in ['a'] then Inc(lineCount);
end;
CloseFile(f);
Label1.Caption := lineCount.ToString;
end;
end.
это так не работает, Char недостаточно для размещения юникодных символов читать нужно построчно, в каждой строке искать вхождения через UTF8Pos
Понятно. Спасибо за наводку!
Обычный Char это 1 байт. Русские буквы в один байт влезают только в старых кодировках, а в новых уникодных нужен совсем другой подход к чтению файла и поиску. Долго обьяснять, для начала грузи весь файл в строку и ищи внутри строки. А если файл очень большой, то читай его построчно.
Файл очень большой, да...
А могут ли в одном файле быть разные кодировки?
Это грех, но всякое бывает. В логах, например.
смотря какой файл. в общем виде там может быть что угодно
Обсуждают сегодня