(PHP 5 >= 5.2.0, PHP 7, PHP 8)
SplFileObject::setCsvControl — CSV の区切り文字、囲み文字、エスケープ文字をセットする
$separator = ",", string $enclosure = "\"", string $escape = "\\"): voidCSV フィールド処理用の 区切り文字と囲み文字とエスケープ文字をセットします。
separator
       separator パラメータで、フィールドのデリミタを設定します。
       シングルバイト文字 1 文字のみでなければなりません。
      
enclosure
       オプションの enclosure パラメータで、フィールド囲いこみ文字を設定します。
       シングルバイト文字 1 文字のみでなければなりません。
      
escape
       オプションの escape パラメータで、エスケープ文字を設定します。
       シングルバイト文字 1 文字のみ、または空文字列でなければなりません。
       空文字列("") を指定すると、(RFC 4180 に準拠していない) 独自仕様のエスケープ機構が無効になります。
      
注意:
enclosureの文字は、フィールド内で2回出力される ことでエスケープされます。しかし、escape文字はその代替として使えます。 デフォルトのパラメータの値""と\"は同じ意味を持ちます。enclosureの文字をescape文字でエスケープすることには、 特別な意味はありません。それ自身をエスケープする意味ですらありません。
        PHP 8.4.0 以降では、escape
        のデフォルト値に依存することは非推奨となりました。
        位置指定の引数か、名前付き引数
        を使用して明示的に指定する必要があります。
       
escape
が空の文字列("")以外に設定されているとき、
» RFC 4180
に準拠しない CSV が生成されたり、PHP の CSV
関数を介してラウンドトリップ(往復変換)でデータが壊れる可能性があります。
escapeのデフォルト値は"\\"
なので、明示的に空の文字列を指定することを推奨します。デフォルト値は、PHP 9.0
以降の将来のバージョンで変更予定です。
値を返しません。
   separator または enclosure が
   1 バイト長ではない場合、ValueError をスローします。
  
   escape が 1 バイト長、または空文字列ではない場合、
   ValueError をスローします。
  
| バージョン | 説明 | 
|---|---|
| 8.4.0 | escapeのデフォルト値に依存することは、
        非推奨になりました。 | 
| 7.4.0 | escapeパラメータは空文字列を受け入れるようになりました。
        この場合、(RFC 4180 に準拠していない) 独自仕様のエスケープ機構が無効になります。 | 
例1 SplFileObject::setCsvControl() の例
<?php
$file = new SplFileObject("data.csv");
$file->setFlags(SplFileObject::READ_CSV);
$file->setCsvControl('|');
foreach ($file as $row) {
    list ($fruit, $quantity) = $row;
    // Do something with values
}
?>data.csv の内容
<?php apples|20 bananas|14 cherries|87 ?>
