>백엔드 개발 >PHP 튜토리얼 >내 PHP 코드가 CSV 파일에서 BOM을 제거하지 못하는 이유는 무엇입니까?

내 PHP 코드가 CSV 파일에서 BOM을 제거하지 못하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-03 05:36:02411검색

Why Does My PHP Code Fail to Remove BOM from CSV Files?

가져온 후 .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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.