ホームページ >バックエンド開発 >PHPチュートリアル >php csvから配列(csvから配列)メソッドとコード

php csvから配列(csvから配列)メソッドとコード

WBOY
WBOYオリジナル
2016-07-25 08:59:391548ブラウズ
  1. //ini_set('memory_limit', '-1'); // CSV が比較的大きい場合は追加できます。
  2. /*
  3. * $file : csv file
  4. * $csvDataArr : header of csv table, eg: arary('name','sex','age') or array(0,1,2)
  5. * $specialhtml : whether do you want to convert special characters to html entities ?
  6. * $removechar : which type do you want to remove special characters in array keys, manual or automatical ?
  7. * edit http://bbs.it-home.org
  8. */
  9. class csv_to_array
  10. {
  11. private $counter;
  12. private $handler;
  13. private $length;
  14. private $file;
  15. private $seprator;
  16. private $specialhtml;
  17. private $removechar = 'manual';
  18. private $csvDataArr;
  19. private $csvData = array();
  20. function __construct($file = '', $csvDataArr = '', $specialhtml = true, $length = 1000, $seprator = ',')
  21. {
  22. $this->counter = 0;
  23. $this->length = $length;
  24. $this->file = $file;
  25. $this->seprator = $seprator;
  26. $this->specialhtml = $specialhtml;
  27. $this->csvDataArr = is_array($csvDataArr) ? $csvDataArr : array();
  28. $this->handler = fopen($this->file, "r");
  29. }
  30. function get_array()
  31. {
  32. $getCsvArr = array();
  33. $csvDataArr = array();
  34. while(($data = fgetcsv($this->handler, $this->length, $this->seprator)) != FALSE)
  35. {
  36. $num = count($data);
  37. $getCsvArr[$this->counter] = $data;
  38. $this->counter++;
  39. }
  40. if(count($getCsvArr) > 0)
  41. {
  42. $csvDataArr = array_shift($getCsvArr);
  43. if($this->csvDataArr) $csvDataArr = $this->csvDataArr;
  44. $counter = 0;
  45. foreach($getCsvArr as $csvValue)
  46. {
  47. $totalRec = count($csvValue);
  48. for($i = 0; $i < $totalRec ; $i++)
  49. {
  50. $key = $this->csvDataArr ? $csvDataArr[$i] : $this->remove_char($csvDataArr[$i]);
  51. if($csvValue[$i]) $this->csvData[$counter][$key] = $this->put_special_char($csvValue[$i]);
  52. }
  53. $counter++;
  54. }
  55. }
  56. return $this->csvData;
  57. }
  58. function put_special_char($value)
  59. {
  60. return $this->specialhtml ? str_replace(array('&','" ','\'','<','>'),array('&','"',''','<','>'),$value) : $value;
  61. }
  62. function remove_char($value)
  63. {
  64. $result = $this->removechar == 'manual' ? $this->remove_char_manual($value) : $this->remove_char_auto($value);
  65. return str_replace(' ','_',trim($result));
  66. }
  67. private function remove_char_manual($value)
  68. {
  69. return str_replace(array('&','"','\'','<','>','(',')','%'),'',trim($value));
  70. }
  71. private function remove_char_auto($str,$x=0)
  72. {
  73. $x==0 ? $str=$this->make_semiangle($str) : '' ;
  74. eregi('[[:punct:]]',$str,$arr);
  75. $str = str_replace($arr[0],'',$str);
  76. return eregi('[[:punct:]]',$str) ? $this->remove_char_auto($str,1) : $str;
  77. }
  78. プライベート関数 make_semiangle($str)
  79. {
  80. $arr = array('0' => '0', '1' => '1', '2' => '2', '3' => '3'、'4' => '5'、'6' => '7'、'8' ' => '8'、'9' => 'A'、'B' => 'C' 'D' => 'E'、'F' => 'G'、'H' => 'I' => 'J'、'K' => 'L'、'M' => 、'N' => 'O'、
  81. 'P' => 'Q'、'R' => '、'S' => 'T'、'U' => 'V'、'W' => W'、'X'、'Y' => 'Z'、'a' => 'b'、'c' => 'd'、'e' => 'f'、'g' => ; 'g'、'h' => 'i'、'j' => 'k' => > 'l'、'm' => 'm'、'n'、
  82. 'o'、'p' => 'p'、'q' => 'q'、'r' => 'r'、's' => 's',
  83. 't' => 't'、'u' => 'u'、'v' => 'v'、'w' => 'w'、'x' => 'x'、
  84. 'y' => 'y'、'z' => 'z',
  85. '(' => '(', ')' => ')', '〔' => '[', '】' => ']'、'【' => '[',
  86. ']' => ']'、'〖' => '[', '〗' => ']'、'”' => '['、'”' => ']'、
  87. '''' => '[', '' => ']'、'{' => '{'、'}' => '}'、'《' => '<',
  88. '》' => '>',
  89. '%' => '%'、'+' => '+'、'—' => '-'、'-' => '-'、'~' => '-',
  90. ':' => ':'、'。' => '.'、'、' => ',', ',' => '.'、'、' => '.',
  91. ';' => ',', '?' => 「?」、「!」 => '!'、'…' => '-'、'‖' => '|',
  92. '”' => '"', ''' => '`', '''' => '`', '|' => '|', '〃' => '"',
  93. ' ' => ' ','$'=>'$','@'=>'@','#'=>'#','^'=>'^','&'=>' &','*'=>'*');
  94. return strtr($str, $arr);
  95. }
  96. function __destruct(){
  97. fclose($this->handler);
  98. }
  99. }
  100. // 例:
  101. $csv = new csv_to_array('user.csv');
  102. echo "
    "; print_r($csv->get_array()); echo "
    ";
  103. ?>
  104. 复制幣
  105. 2. 一般的な機能を使用する

    1. 関数 csv_to_array($csv)
    2. {
    3. $len = strlen($csv);
    4. $table = array();
    5. $cur_row = array();
    6. $cur_val = "";
    7. $state = "最初のアイテム";
    8. for ($i = 0; $i {
    9. //sleep(1000);
    10. $ch = substr($csv,$i,1);
    11. if ($state == "最初の項目")
    12. {
    13. if ($ch == '"') $state = "引用符で囲まれています";
    14. elseif ($ch == ",") //空
    15. {
    16. $cur_row[] = ""; //最初の項目で完了
    17. $state = "最初の項目"
    18. }
    19. elseif ($ch == "n")
    20. $ cur_row[] = $cur_val;
    21. $cur_row = array();
    22. $state = "最初の項目" }
    23. elseif ($ch == "; r") $state = "改行を待ちます。そうであれば行を閉じます!";
    24. else
    25. {
    26. $cur_val .= $ch;
    27. $state = "引用符ではなく収集";
    28. }
    29. }
    30. elseif ($state == "引用符で囲まれています")
    31. {
    32. if ($ch == '"') $state = "潜在的な終了引用符が見つかりました";
    33. else $cur_val .= $ch;
    34. }
    35. elseif ($state == "潜在的な終了引用符が見つかりました")
    36. {
    37. if ($ch == '"')
    38. {
    39. $cur_val .= '"';
    40. $state = "引用符で囲まれています";
    41. }
    42. elseif ($ch == ',')
    43. {
    44. $cur_row[] = $cur_val;
    45. $cur_val = "";
    46. $state = "最初のアイテム";
    47. }
    48. elseif ($ch == "n")
    49. {
    50. $cur_row[] = $cur_val;
    51. $table[] = $cur_row;
    52. $cur_row = array();
    53. $cur_val = "";
    54. $state = "最初のアイテム";
    55. }
    56. elseif ($ch == "r") $state = "改行するなら行を閉じてください!";
    57. else
    58. {
    59. $cur_val .= $ch;
    60. $state = "引用符で囲まれています";
    61. }
    62. }
    63. elseif ($state == "改行を待ちます。その場合は行を閉じます!")
    64. {
    65. if ($ch == "n")
    66. {
    67. $cur_row[] = $cur_val ;
    68. $cur_val = "";
    69. $table[] = $cur_row;
    70. $cur_row = array();
    71. $state = "最初のアイテム";
    72. }
    73. else
    74. {
    75. $cur_row[] = $cur_val;
    76. $table[] = $cur_row;
    77. $cur_row = array();
    78. $cur_val = $ch;
    79. $state = "引用ではなく収集";
    80. }
    81. }
    82. elseif ($state == "引用符ではなく収集")
    83. {
    84. if ($ch == ",")
    85. {
    86. $cur_row[] = $cur_val;
    87. $cur_val = "";
    88. $state = "最初のアイテム";
    89. }
    90. elseif ($ch == "n")
    91. {
    92. $cur_row[] = $cur_val;
    93. $table[] = $cur_row;
    94. $cur_row = array();
    95. $cur_val = "";
    96. $state = "最初のアイテム";
    97. }
    98. elseif ($ch == "r") $state = "改行を待ちます。改行した場合は行を閉じます!";
    99. else $cur_val .= $ch;
    100. }
    101. }
    102. $table を返します。
    103. }
    104. //csv 文字列を渡し、php 配列を取得します
    105. // 例:
    106. $arr = csv_to_array(file_get_contents('user.csv'));
    107. echo "
      "; print_r($arr);   エコー「
    108. ?>
    复制代

    または者

    1. $arrCSV = 配列();
    2. // CSV を開きます
    3. if (($handle = fopen("user.csv", "r")) !==FALSE) {
    4. // 親配列のキーを 0 に設定します
    5. $key = 0;
    6. // 利用可能なデータがある間、区切り文字 (,) を使用して無制限の回数 (0) をループします
    7. while (($data = fgetcsv($handle, 0, ",")) !==FALSE) {
    8. // をカウントします各行のキーの合計
    9. $c = count($data);
    10. //配列
    11. に ($x=0;$x $key++;
    12. } // end while
    13. // CSV ファイルを閉じる
    14. fclose($handle);
    15. } // end if
    16. echo "
      "; print_r($arrCSV); echo "
      ";
    17. ?>
    倍定コード

    より良いものに至るまで、自分の実際の要求が個人の愛情によく合っていることを確認し、実際の作業中のcsv配列の要求も少なく、大家が多数、多数の掌握を確立しています。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。