Bagaimana untuk Mengalih keluar BOM daripada Fail CSV yang Diimport?

DDD
Lepaskan: 2024-11-03 04:47:30
asal
764 orang telah melayarinya

How to Remove BOM from Imported CSV Files?

Mengalih keluar BOM daripada Fail CSV yang Diimport

Apabila mengimport fail .csv, adalah perkara biasa untuk menemui BOM (Byte Order Mark), yang boleh mengganggu pemprosesan data. Isu ini boleh diselesaikan dengan mengalih keluar BOM daripada fail.

Satu kaedah untuk mengalih keluar BOM menggunakan ungkapan biasa:

$new_file = preg_replace('/[\x00-\x1F\x80-\xFF]/', '', $file);
Salin selepas log masuk

Walau bagaimanapun, kaedah ini mungkin tidak sentiasa boleh dipercayai. Pendekatan alternatif menggunakan fungsi file_get_contents disyorkan:

$content = file_get_contents($filepath);
file_put_contents($filepath, str_replace("\xEF\xBB\xBF", '', $content));
Salin selepas log masuk

Pendekatan ini menimpa fail dengan data yang dialih keluar BOM, membolehkan anda meneruskan pemprosesan fail tanpa gangguan BOM.

Walau bagaimanapun, menggunakan file_put_contents menutup fail, yang mungkin mengganggu skrip sedia ada anda. Untuk menyelesaikan masalah ini, gunakan fopen untuk membuka semula fail selepas menulis:

$file = fopen($filepath, "r") or die("Error opening file");
Salin selepas log masuk

Dengan melaksanakan teknik ini, anda boleh mengalih keluar BOM daripada fail .csv yang diimport dengan berkesan dan memastikan pemprosesan data yang lancar dalam skrip anda.

Atas ialah kandungan terperinci Bagaimana untuk Mengalih keluar BOM daripada Fail CSV yang Diimport?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan