本篇文章主要介紹php 實作截取GBK文檔某個位置開始的n個字元方法,有興趣的朋友參考下,希望對大家有幫助。
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內容:
dkei20王nnso
測試指令:
./cut.php 6 1
#查看結果:
hexdump -C t.txt && hexdump - C a.txt
以上就是本文的全部內容,希望對大家的學習有幫助。
相關推薦:
詳述Sublime Text 開啟GBK 格式中文亂碼如何解決
php 透過iconv將字串從GBK轉換為UTF8字元集的方法
#
以上是php 實作截取GBK文檔某個位置開始的n個字元方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!