日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

PHP讀取和寫入CSV文件的示例代碼

瀏覽:31日期:2022-06-10 17:07:39
目錄
  • 1. 什么是 CSV 文件
  • 2. 從 CSV 文件中讀取數據
  • 3. 將數據寫入 CSV 文件

1. 什么是 CSV 文件

CSV(逗號分隔值)文件是使用逗號分隔信息的文本文件。該文件的每一行都是一條數據記錄,也就意味著它可以用于以表格的形式展現信息。

2. 從 CSV 文件中讀取數據

我將使用內置函數 file 從 CSV 文件中讀取數據,然后使用 str_getcsv() 解析包含逗號的字符串。

在介紹如何使用str_getcsv() 函數之前,我想向你介紹如何輸出 CSV 文件中的數據。

<?php    if($_FILES){var_dump(file($_FILES["file"]["tmp_name"], FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES));    }?>?<html>    <body><form method="post" enctype="multipart/form-data">    <input type="file" name="file" />    <button>upload</button></form>    </body></html>

當我使用上面的代碼上傳文件時,輸出以下數據:

如圖所示,每個字符串中都有逗號,每個逗號將一條信息與另一條信息隔開。

使用 array_map() 函數,并且 str_getcsv() 作為回調函數,該回調將解析每個具有逗號的字符串并將它們分隔在一個數組中。

if($_FILES){    //loop through the csv file into an array    $theCSV = array_map("str_getcsv", file($_FILES["file"]["tmp_name"], FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES));    //dump result    var_dump($theCSV);}

輸出如下:

輸出的數據看起來比之前要好得多,我們將列標題(全名、QQ、電子郵件)作為該數組的第一個元素。

我們使用 array_walk() 函數遍歷此數組 ,然后提供一個回調函數,它將列標題(全名、QQ、電子郵件)和每個 CSV 數據組合為一個新數組。

if($_FILES){    //loop through the csv file into an array    $theCSV = array_map("str_getcsv", file($_FILES["file"]["tmp_name"], FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES));    /*Walk through the array and combine the headers which is the first element of our csv array with the rest of the csv data*/    array_walk($theCSV, function(&$ary) use($theCSV) {$ary = array_combine($theCSV[0], $ary);    });    //dump result    var_dump($theCSV);}?>

注意,在上面的回調函數中,我使用了變量& 運算符將 $ary 通過引用傳遞給函數,這使的我們可以修改原始數組。當我們運行上面的代碼時,這就是我們的 CSV 數組現在的樣子:

注意這里有個問題:這個新數組的第一個元素是表頭,因為我們之前讓它與 CSV 數組的其他數組組裝在了一起??梢允褂?array_shift() 來解決這個問題。

if($_FILES){    //loop through the csv file into an array    $theCSV = array_map("str_getcsv", file($_FILES["file"]["tmp_name"], FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES));    /*Walk through the array and combine the headers which is the first element of our csv array with the rest of the csv data*/    array_walk($theCSV, function(&$ary) use($theCSV) {$ary = array_combine($theCSV[0], $ary);    });    //remove column headers which is the first element    array_shift($theCSV);    //dump result    var_dump($theCSV);}

這就是我們最終的 CSV 數組的樣子

將上面的代碼封裝成一個函數,如下:

function readCSV($file){    if(empty($file) || !file_exists($file)) return;    //store the column headers    $headers = null;    $theCSV = array_map("str_getcsv", file($file, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES));    /*Walk through the array and combine the headers which is the first element of our csv array with the rest of the csv data*/    array_walk($theCSV, function(&$ary) use($theCSV, &$headers) {    $ary = array_combine($theCSV[0], $ary);    //store the headers    $headers = $theCSV[0];    });    //remove column headers which is the first element of our csv array    array_shift($theCSV);    //return data    return array("headers" => $headers,"data" => $theCSV    );}

3. 將數據寫入 CSV 文件

將數據寫入 CSV 文件,其邏輯是使用 fopen() 函數以附加模式打開 CSV 文件, 然后用 fputcsv() 解析我們要寫入 CSV 文件的數據,然后此方法將這些數據寫入文件流當中。

if($_SERVER["REQUEST_METHOD"] == "POST"){    $file = "./my_csv_file.csv";    //loop through the csv file into an array    $csvData = readCSV($file);    //create array to store the new data    $newData = [];    //loop through headers and then add values as a new array    foreach($csvData["headers"] as $index => $key){if($key == "Full Name"){    $newData[$key] = $_POST["full_name"];}elseif($key == "Email"){    $newData[$key] = $_POST["email"];}elseif($key == "Phone"){    $newData[$key] = $_POST["phone"];}else{    $newData[$key] = "";}    }    var_dump($newData);}

如圖所示就是我們將寫入到 CSV 文件的數組的數據

在我們將這些數據寫入到 CSV 文件之前,我們必須去掉 key,我們可以使用 array_values() 函數

if($_SERVER["REQUEST_METHOD"] == "POST"){    $file = "./my_csv_file.csv";    //loop through the csv file into an array    $csvData = readCSV($file);    //create array to store the new data    $newData = [];    //loop through headers and then add values as a new array    foreach($csvData["headers"] as $index => $key){if($key == "Full Name"){    $newData[$key] = $_POST["full_name"];}elseif($key == "Email"){    $newData[$key] = $_POST["email"];}elseif($key == "Phone"){    $newData[$key] = $_POST["phone"];}else{    $newData[$key] = "";}    }    //open the csv file as in append mode    $fp = fopen($file, "a+");    //remove keys from new data    $newData = array_values($newData);    //append data to csv file    fputcsv($f, $newData);    //close the resource    fclose($fp);}

不出意外的話,數據就會成功寫入到 CSV 文件當中去了。

以上就是PHP讀取和寫入CSV文件的示例代碼的詳細內容,更多關于PHP CSV文件的資料請關注其它相關文章!

標簽: PHP
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲国产成人二区| 成人国产综合| 日韩国产高清在线| 精品中文字幕一区二区三区av| 国产丝袜一区| 国产精品欧美一区二区三区不卡| 亚洲精品在线国产| 亚洲资源在线| 亚洲精品动态| av高清不卡| 四虎成人av| 最新亚洲国产| 精品伊人久久| 天堂成人免费av电影一区 | 日产午夜精品一线二线三线| 国产精品v亚洲精品v日韩精品| 久久国产日本精品| 中日韩男男gay无套| 国产精品一线天粉嫩av| 日韩欧美另类一区二区| 性欧美精品高清| 日韩啪啪电影网| 视频在线观看一区| 精品精品国产三级a∨在线| 女人av一区| 国产欧美在线观看免费| 日韩av一二三| 亚洲精品网址| 麻豆国产精品777777在线| 国产一区二区中文| 久久精品一区| 乱人伦精品视频在线观看| 国产精品欧美大片| 亚洲欧洲一区| 99精品国产一区二区三区| 国产日产精品_国产精品毛片| 在线一区免费观看| 伊人精品一区| 欧美日本不卡高清| 午夜亚洲福利| 日本欧美在线看| 亚洲涩涩在线| 蜜桃视频一区二区三区| 精品免费在线| 亚洲午夜91| 免费看日韩精品| 亚洲午夜免费| 国产日本精品| 日本在线高清| 蜜桃av一区二区三区电影| 美美哒免费高清在线观看视频一区二区| 日韩激情综合| 欧美三级精品| 综合色一区二区| 超级白嫩亚洲国产第一| 免费日韩视频| 不卡专区在线| 亚洲精品成人一区| 精品三级av在线导航| 日韩一区二区在线免费| 亚洲调教视频在线观看| 蜜桃精品在线| 日韩在线观看不卡| 伊人精品一区| 日韩一区二区三区四区五区| 欧美片第1页综合| 中文字幕在线高清| 视频一区欧美精品| 日韩在线麻豆| 免费在线小视频| 午夜一级久久| 国产精品久久久久久模特| 中文字幕人成乱码在线观看| 日韩在线短视频| 视频一区欧美精品| 丁香婷婷久久| 天堂va蜜桃一区二区三区| 国产精品午夜一区二区三区| 欧美黄色一区| 男人的天堂久久精品| 精品一区二区三区免费看| 蜜臀av免费一区二区三区| 国产精品永久| 五月婷婷六月综合| 久久免费精品| 日韩三级视频| 亚洲综合精品四区| 国产成人免费av一区二区午夜| 好吊日精品视频| 麻豆精品久久| 日韩精品一二区| 日本久久成人网| 久久亚洲人体| 欧美在线91| 亚洲日本欧美| 日韩在线一二三区| 久久久久久黄| 精品精品国产三级a∨在线| 国产探花一区在线观看| 亚洲综合图色| 欧美日韩国产在线观看网站| 99精品电影| 欧美三区四区| 激情丁香综合| 91成人精品视频| 91九色精品国产一区二区| 中文另类视频| 日韩黄色大片| 国产一区日韩一区| 国产农村妇女精品一二区| 亚洲欧洲日本mm| 亚洲精品黄色| 欧美日韩视频免费看| 成人国产精品一区二区免费麻豆| 99精品一区| 久久精品成人| 国产亚洲人成a在线v网站| 激情欧美一区| 国产一区二区精品| 老牛国内精品亚洲成av人片| 高清日韩中文字幕| 亚洲二区三区不卡| 91综合久久爱com| 欧美不卡高清一区二区三区| 亚洲欧美日韩国产一区| 欧美激情福利| 激情欧美国产欧美| 欧美视频二区| 国产一区日韩欧美| 欧美激情在线精品一区二区三区| 亚洲国产欧美日本视频| 欧美日韩一区二区三区不卡视频| 久久久男人天堂| 石原莉奈在线亚洲二区| 国产精品chinese| 亚洲成人二区| 日本欧美国产| 91精品尤物| 免费视频亚洲| 国产一区亚洲| 午夜欧美在线| 天使萌一区二区三区免费观看| 啪啪亚洲精品| 久久久久亚洲| 欧美xxxx中国| 亚洲18在线| 免费在线视频一区| 国产一区二区三区自拍| 蜜桃久久av| 久久久久久久久久久妇女| 麻豆精品在线| 日韩精品一二三| 国产高清日韩| 国产欧美啪啪| 欧美亚洲tv| 午夜久久影院| 国产模特精品视频久久久久| 国产一区二区三区精品在线观看| 亚洲精品91| 羞羞答答国产精品www一本| 狠狠躁少妇一区二区三区| 美女亚洲一区| 国产精品视频首页| 欧美精品二区| 成人影视亚洲图片在线| 免费久久99精品国产自在现线| 精品视频高潮| 日本亚洲视频在线| 亚洲乱码视频| 美腿丝袜在线亚洲一区| 欧美天堂在线| 亚洲乱亚洲高清| 中文日韩欧美| 日本一区二区中文字幕| 日韩精品亚洲专区| 国产人成精品一区二区三| 黄色欧美日韩| 国产午夜久久av| 亚洲一区资源| 中文字幕日韩高清在线| 天使萌一区二区三区免费观看| 日韩欧美不卡| 日本亚洲视频在线| 欧美1级日本1级| 亚洲欧洲日韩| 国产成人精品一区二区三区在线| 日韩av有码| 免费看欧美美女黄的网站| 91精品xxx在线观看| 国产免费av国片精品草莓男男| 欧美久久久网站| 麻豆成人av在线| 99久久亚洲精品蜜臀| 日韩一区精品| 日韩精品免费一区二区三区| 美女久久一区| 卡一精品卡二卡三网站乱码| 黄色成人91| 裤袜国产欧美精品一区| 日本不卡视频在线观看|