Dieser Artikel stellt hauptsächlich die Methode zum Abfangen von n Zeichen ab einer bestimmten Position im GBK-Dokument in PHP vor. Ich hoffe, dass er für alle hilfreich ist.
cut.php:
#!/usr/bin/php <?php define('INPUT_FILE', 't.txt'); define('OUTPUT_FILE', 'a.txt'); $pos = max(intval($argv[1]), 0); $len = max(intval($argv[2]), 0); $file_size = filesize(INPUT_FILE); if($pos >= $file_size) exit; $fp = fopen(INPUT_FILE, 'rb'); $point = 0; //current byte position $string = ''; while(ftell($fp) < $file_size) { if($point >= $pos + $len) break;$byte = fread($fp, 1); //php version >= 5.4 $char = unpack('C', $byte)[1]; if($char <= 0x7f) { //single byte if($point >= $pos) $string .= $byte; $point += 1; continue; } else { //double bytes if($point >= $pos) { $string .= $byte.fread($fp, 1); } else { fseek($fp, 1, SEEK_CUR); } $point += 1; continue; } } fclose($fp); file_put_contents(OUTPUT_FILE, $string); ?>
T.txt-Inhalt der Quelldatei:
dkei20王nnso
Testbefehl:
./cut.php 6 1
Ergebnisse anzeigen:
hexdump -C t.txt && hexdump - C a.txt
Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, dass er für das Studium aller hilfreich sein wird.
Verwandte Empfehlungen:
Processing Sublime Text OpeningGBKChinesisches verstümmeltes Format
Details zum Lösen der verstümmelten chinesischen Zeichen in Sublime Text beim Öffnen des GBK-Formats
Das obige ist der detaillierte Inhalt vonPHP implementiert eine Methode zum Abfangen von n Zeichen ab einer bestimmten Position in einem GBK-Dokument. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!