欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解PHP導(dǎo)入導(dǎo)出CSV文件

 更新時間:2014年11月03日 10:27:33   投稿:hebedich  
項目開發(fā)中,很多時候要將外部CSV文件導(dǎo)入到數(shù)據(jù)庫中或者將數(shù)據(jù)導(dǎo)出為CSV文件,那么具體該如何實現(xiàn)呢?本文將使用PHP并結(jié)合mysql,實現(xiàn)了CSV格式數(shù)據(jù)的導(dǎo)入和導(dǎo)出功能。

我們先準備mysql數(shù)據(jù)表,假設(shè)項目中有一張記錄學(xué)生信息的表student,并有id,name,sex,age分別記錄學(xué)生的姓名、性別、年齡等信息。

復(fù)制代碼 代碼如下:

CREATE TABLE `student` (  
    `id` int(11) NOT NULL auto_increment,  
    `name` varchar(50) NOT NULL,  
    `sex` varchar(10) NOT NULL,  
    `age` smallint(3) NOT NULL default '0',  
    PRIMARY KEY  (`id`)  
) ENGINE=MyISAM  DEFAULT CHARSET=utf8; 

我們還需要一個html交互頁面,放置導(dǎo)入表單和導(dǎo)出按鈕。

復(fù)制代碼 代碼如下:

<form id="addform" action="do.php?action=import" method="post" enctype="multipart/form-data"> 
    <p>請選擇要導(dǎo)入的CSV文件:<br/><input type="file" name="file"> <input type="submit" 
    class="btn" value="導(dǎo)入CSV"> 
    <input type="button" class="btn" value="導(dǎo)出CSV" onclick="window.location.href='do.php?  
    action=export'"></p> 
</form> 

選擇好本地csv文件后,點擊導(dǎo)入,提交到do.php?action=import處理,而點擊導(dǎo)出按鈕則請求地址do.php?action=export進行數(shù)據(jù)導(dǎo)出處理。

1.導(dǎo)入CSV
do.php需要根據(jù)get過來的參數(shù),分別處理導(dǎo)入和導(dǎo)出過程,php結(jié)構(gòu)如下:

復(fù)制代碼 代碼如下:

include_once ("connect.php"); //連接數(shù)據(jù)庫  
$action = $_GET['action'];  
if ($action == 'import') //導(dǎo)入CSV  
{  
    //導(dǎo)入處理  
}elseif($action=='export') //導(dǎo)出CSV  
{  
    //導(dǎo)出處理   

導(dǎo)入CSV處理流程:校驗csv文件合法性(本文忽略)->打開讀入并解析csv文件中的字段->循環(huán)獲取各字段值->批量添加到數(shù)據(jù)表中->完成。

復(fù)制代碼 代碼如下:

if ($action == 'import') { //導(dǎo)入CSV  
    $filename = $_FILES['file']['tmp_name'];  
    if(emptyempty ($filename))  
    {  
        echo '請選擇要導(dǎo)入的CSV文件!';  
        exit;  
    }  
    $handle = fopen($filename, 'r');  
    $result = input_csv($handle); //解析csv  
    $len_result = count($result);  
    if($len_result==0)  
    {  
        echo '沒有任何數(shù)據(jù)!';  
        exit;  
    }  
    for($i = 1; $i < $len_result; $i++) //循環(huán)獲取各字段值  
    {  
        $name = iconv('gb2312', 'utf-8', $result[$i][0]); //中文轉(zhuǎn)碼  
        $sex = iconv('gb2312', 'utf-8', $result[$i][1]);  
        $age = $result[$i][2];  
        $data_values .= "('$name','$sex','$age'),";  
    }  
    $data_values = substr($data_values,0,-1); //去掉最后一個逗號  
    fclose($handle); //關(guān)閉指針  
    $query = mysql_query("insert into student (name,sex,age) values $data_values"); //批量插入數(shù)據(jù)表中  
    if($query)  
    {  
        echo '導(dǎo)入成功!';  
    }else{  
        echo '導(dǎo)入失??!';  
    }  

注意php自帶的fgetcsv函數(shù)可以輕松處理csv,使用該函數(shù)可以從文件指針中讀入一行并解析CSV字段。下面的函數(shù)將csv文件字段解析并以數(shù)組的形式返回。

復(fù)制代碼 代碼如下:

function input_csv($handle)  
{  
    $out = array ();  
    $n = 0;  
    while ($data = fgetcsv($handle, 10000))  
    {  
        $num = count($data);  
        for ($i = 0; $i < $num; $i++)  
        {  
            $out[$n][$i] = $data[$i];  
        }  
        $n++;  
    }  
    return $out;  

此外在導(dǎo)入到數(shù)據(jù)庫中時,我們采用的是批量插入而不是一條條插入的,因此在構(gòu)建SQL語句時,要稍作處理,見代碼。

2.導(dǎo)出CSV

我們知道csv文件是由逗號分割符組成的純文本文件,你可以用excel打開,效果跟xls表個一樣。
導(dǎo)出CSV處理流程:讀取學(xué)生信息表->循環(huán)記錄構(gòu)建逗號分隔的字段信息->設(shè)置header信息->導(dǎo)出文件(下載)到本地

復(fù)制代碼 代碼如下:

...  
}elseif ($action=='export') //導(dǎo)出CSV  
{  
    $result = mysql_query("select * from student order by id asc");  
    $str = "姓名,性別,年齡\n";  
    $str = iconv('utf-8','gb2312',$str);  
    while($row=mysql_fetch_array($result))  
    {  
        $name = iconv('utf-8','gb2312',$row['name']); //中文轉(zhuǎn)碼  
        $sex = iconv('utf-8','gb2312',$row['sex']);  
        $str .= $name.",".$sex.",".$row['age']."\n"; //用引文逗號分開  
    }  
    $filename = date('Ymd').'.csv'; //設(shè)置文件名  
    export_csv($filename,$str); //導(dǎo)出  

要將數(shù)據(jù)導(dǎo)出到本地即下在,需要修改header信息,代碼如下:

復(fù)制代碼 代碼如下:

function export_csv($filename,$data)  
{  
    header("Content-type:text/csv");  
    header("Content-Disposition:attachment;filename=".$filename);  
    header('Cache-Control:must-revalidate,post-check=0,pre-check=0');  
    header('Expires:0');  
    header('Pragma:public');  
    echo $data;  
}

注意導(dǎo)入和導(dǎo)出的過程中,因為我們使用的是統(tǒng)一UTF-8編碼,遇到中文字符一定要記得轉(zhuǎn)碼,否則可能會出現(xiàn)中文亂碼的情況。
好了,本文講解到此,后面我還會有文章介紹PHP結(jié)合mysql導(dǎo)入導(dǎo)出excel,以及xml的導(dǎo)入導(dǎo)出,敬請關(guān)注。

相關(guān)文章

  • laravel框架關(guān)于搜索功能的實現(xiàn)

    laravel框架關(guān)于搜索功能的實現(xiàn)

    本文是作者整理的關(guān)于laravel框架搜索功能的實現(xiàn)原理,并附上了詳細代碼,有需要的小伙伴請持續(xù)關(guān)注!
    2018-03-03
  • PHP永久登錄、記住我功能實現(xiàn)方法和安全做法

    PHP永久登錄、記住我功能實現(xiàn)方法和安全做法

    這篇文章主要介紹了PHP永久登錄、記住我功能實現(xiàn)方法和安全做法,本文著重講解用數(shù)據(jù)庫實現(xiàn)更安全的永久登錄、記住我功能,需要的朋友可以參考下
    2015-04-04
  • php實現(xiàn)屏蔽掉黑帽SEO的搜索關(guān)鍵字

    php實現(xiàn)屏蔽掉黑帽SEO的搜索關(guān)鍵字

    這篇文章主要介紹了php實現(xiàn)屏蔽掉黑帽SEO的搜索關(guān)鍵字的相關(guān)資料,這里推薦給大家,有需要的小伙伴可以參考下。
    2015-04-04
  • C#使用PHP服務(wù)端的Web Service通信實例

    C#使用PHP服務(wù)端的Web Service通信實例

    這篇文章主要介紹了C#使用PHP服務(wù)端的Web Service通信實例,需要的朋友可以參考下
    2014-04-04
  • php制作簡單模版引擎

    php制作簡單模版引擎

    模板引擎(這里特指用于Web開發(fā)的模板引擎)是為了使用戶界面與業(yè)務(wù)數(shù)據(jù)(內(nèi)容)分離而產(chǎn)生的,它可以生成特定格式的文檔,用于網(wǎng)站的模板引擎就會生成一個標(biāo)準的HTML文檔。
    2016-04-04
  • ThinkPHP添加更新標(biāo)簽的方法

    ThinkPHP添加更新標(biāo)簽的方法

    這篇文章主要介紹了ThinkPHP添加更新標(biāo)簽的方法,在前文所述刪除blog標(biāo)簽的基礎(chǔ)上實現(xiàn)同步更新標(biāo)簽,是ThinkPHP非常實用的技巧,需要的朋友可以參考下
    2014-12-12
  • eclipse php wamp配置教程

    eclipse php wamp配置教程

    這篇文章主要為大家詳細介紹了eclipse php wamp配置教程,極其簡單的php入門教程,感興趣的小伙伴們可以參考一下
    2016-06-06
  • php實現(xiàn)統(tǒng)計IP數(shù)及在線人數(shù)的示例代碼

    php實現(xiàn)統(tǒng)計IP數(shù)及在線人數(shù)的示例代碼

    這篇文章主要介紹了php實現(xiàn)統(tǒng)計IP數(shù)及在線人數(shù)的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 淺析Yii2緩存的使用

    淺析Yii2緩存的使用

    一個有緩存的框架可以說是一個好的框架。下面小編通過本文給大家介紹yii2中是如何使用緩存的,非常具有參考借鑒價值,感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • laravel 實現(xiàn)根據(jù)字段不同值做不同查詢

    laravel 實現(xiàn)根據(jù)字段不同值做不同查詢

    今天小編就為大家分享一篇laravel 實現(xiàn)根據(jù)字段不同值做不同查詢,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10

最新評論