亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

我們先準(zhǔn)備mysql數(shù)據(jù)表,假設(shè)項(xiàng)目中有一張記錄學(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; 

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

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

<form id="addform" action="do.php?action=import" method="post" enctype="multipart/form-data"> 
    <p>請(qǐng)選擇要導(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文件后,點(diǎn)擊導(dǎo)入,提交到do.php?action=import處理,而點(diǎn)擊導(dǎo)出按鈕則請(qǐng)求地址do.php?action=export進(jìn)行數(shù)據(jù)導(dǎo)出處理。

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

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

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

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

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

if ($action == 'import') { //導(dǎo)入CSV  
    $filename = $_FILES['file']['tmp_name'];  
    if(emptyempty ($filename))  
    {  
        echo '請(qǐng)選擇要導(dǎo)入的CSV文件!';  
        exit;  
    }  
    $handle = fopen($filename, 'r');  
    $result = input_csv($handle); //解析csv  
    $len_result = count($result);  
    if($len_result==0)  
    {  
        echo '沒(méi)有任何數(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); //去掉最后一個(gè)逗號(hào)  
    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ù)庫(kù)中時(shí),我們采用的是批量插入而不是一條條插入的,因此在構(gòu)建SQL語(yǔ)句時(shí),要稍作處理,見(jiàn)代碼。

2.導(dǎo)出CSV

我們知道csv文件是由逗號(hào)分割符組成的純文本文件,你可以用excel打開(kāi),效果跟xls表個(gè)一樣。
導(dǎo)出CSV處理流程:讀取學(xué)生信息表->循環(huán)記錄構(gòu)建逗號(hào)分隔的字段信息->設(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"; //用引文逗號(hào)分開(kāi)  
    }  
    $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)出的過(guò)程中,因?yàn)槲覀兪褂玫氖墙y(tǒng)一UTF-8編碼,遇到中文字符一定要記得轉(zhuǎn)碼,否則可能會(huì)出現(xiàn)中文亂碼的情況。
好了,本文講解到此,后面我還會(huì)有文章介紹PHP結(jié)合mysql導(dǎo)入導(dǎo)出excel,以及xml的導(dǎo)入導(dǎo)出,敬請(qǐng)關(guān)注。

相關(guān)文章

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

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

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

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

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

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

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

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

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

    php制作簡(jiǎn)單模版引擎

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

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

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

    eclipse php wamp配置教程

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

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

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

    淺析Yii2緩存的使用

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

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

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

最新評(píng)論