가져온 후 .csv 파일에서 BOM 제거: 문제 해결
.csv 파일을 가져올 때 바이트 순서 표시( BOM)을 사용하여 데이터 무결성과 호환성을 보장합니다. 그러나 preg_replace 및 str_replace를 사용한 시도가 실패했다고 언급하셨습니다. 코드를 분석하고 대체 접근 방식을 살펴보겠습니다.
코드는 fopen을 사용하여 읽을 수 있도록 CSV 파일을 여는 것으로 시작됩니다. 그런 다음 fgetcsv를 사용하여 라인을 전처리하고 utf8_encode를 사용하여 UTF-8로 변환하려고 시도합니다. 그러나 이 섹션에는 BOM 제거가 누락되어 있습니다.
제공된 솔루션에서는 BOM을 명시적으로 제거하기 위해 RemoveBomUtf8이라는 함수를 추가하는 것이 좋습니다. 일반적으로 BOM은 UTF-8에서 처음 3바이트 0xEF, 0xBB 및 0xBF로 나타납니다. 인코딩된 파일. 추가 처리 전에 파일 내용에 대해 이 함수를 호출할 수 있습니다.
또한 코드는 원본 CSV 파일을 수정된 데이터로 덮어쓰므로 후속 작업에 영향을 미칠 수 있습니다. 이를 방지하려면 임시 파일을 생성하고 해당 파일의 데이터를 수정한 다음 다시 원래 위치로 이동하는 것이 좋습니다.
다음은 BOM 제거 기능과 파일 덮어쓰기 방지 기능을 통합한 업데이트된 코드 버전입니다.
<code class="php">function removeBomUtf8($s){ if(substr($s,0,3)==chr(hexdec('EF')).chr(hexdec('BB')).chr(hexdec('BF'))){ return substr($s,3); }else{ return $s; } } setlocale(LC_ALL, 'nl_NL'); ini_set('auto_detect_line_endings',TRUE); require_once(ABSPATH.'wp-admin/includes/file.php' ); $path = get_home_path(); $filepath = $path .'wp-content/themes/pon/testing.csv'; $content = file_get_contents($filepath); file_put_contents($filepath, str_replace("\xEF\xBB\xBF",'', $content)); // Create temporary file $tempfile = tempnam(sys_get_temp_dir(), 'csv_'); fopen($tempfile, "w"); // Process lines and remove BOM $file = fopen($filepath, "r") or die("Error opening file"); while(($line = fgetcsv($file, 1000, ";")) !== FALSE) { fputcsv(fopen($tempfile, 'w'), $line); } // Move temporary file to original location fclose($file); unlink($filepath); rename($tempfile, $filepath); // Continue your processing ...</code>
이 접근 방식은 BOM을 효과적으로 제거하고 파일 덮어쓰기를 방지하며 원본 코드의 기능을 보존해야 합니다.
위 내용은 내 PHP 코드가 CSV 파일에서 BOM을 제거하지 못하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!