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

php操作csv文件代碼實(shí)例匯總

 更新時(shí)間:2014年09月22日 10:05:37   投稿:junjie  
這篇文章主要介紹了php操作csv文件代碼實(shí)例匯總,本文給出6個(gè)操作CSV文件的代碼實(shí)例,包括讀取、寫(xiě)入、讀取指定區(qū)間等,需要的朋友可以參考下

1.讀取csv數(shù)據(jù), 輸出到sales.csv文件中:

$sales = array(
  array('Northeast', '2004-01-01', '2004-02-01', 12.54),
  array('Northwest', '2004-01-01', '2004-02-01', 546.33),
  array('Southeast', '2004-01-01', '2004-02-01', 93.26),
  array('Southwest', '2004-01-01', '2004-02-01', 945.21),
  array('All Regions', '---', '--', 1597.34),
);

$fh = fopen('sales.csv', 'w') or die("Can't open sales.csv");
foreach($sales as $sales_line){
  if(fputcsv($fh, $sales_line) === false){
    die("Can't write CSV line");  
  }
}

fclose($fh) or die("Can't close sales.csv");

2. 讀取csv數(shù)據(jù), 使用特殊的流輸出

$sales = array(
  array('Northeast', '2004-01-01', '2004-02-01', 12.54),
  array('Northwest', '2004-01-01', '2004-02-01', 546.33),
  array('Southeast', '2004-01-01', '2004-02-01', 93.26),
  array('Southwest', '2004-01-01', '2004-02-01', 945.21),
  array('All Regions', '---', '--', 1597.34),
);

$fh = fopen('php://output', 'w');
foreach($sales as $sales_line){
  if(fputcsv($fh, $sales_line) === false){
    die("Can't write CSV line");  
  }
}

fclose($fh);

3. 讀取csv數(shù)據(jù), 輸出到緩沖中

$sales = array(
  array('Northeast', '2004-01-01', '2004-02-01', 12.54),
  array('Northwest', '2004-01-01', '2004-02-01', 546.33),
  array('Southeast', '2004-01-01', '2004-02-01', 93.26),
  array('Southwest', '2004-01-01', '2004-02-01', 945.21),
  array('All Regions', '---', '--', 1597.34),
);

ob_start();
$fh = fopen('php://output', 'w') or die("Can't open php://output");
foreach($sales as $sales_line){
  if(fputcsv($fh, $sales_line) === false){
    die("Can't write CSV line");  
  }
}

fclose($fh) or die("Can't close php://output");
$output = ob_get_contents();
ob_end_clean();

4. 讀取csv文件的數(shù)據(jù)

$fp = fopen('sample3.csv', 'r') or die("can't open file");
print "<table>\n";
while($csv_line = fgetcsv($fp)){
  print '<tr>';
  for($i=0, $j=count($csv_line); $i<$j; $i++){
    // print '<td>'.htmlentities($csv_line[$i]).'</td>';  
    print '<td>'.htmlentities(iconv("gb2312","utf-8",$csv_line[$i])).'</td>';
  }
  print "</tr>\n";
}
print "</table>\n";
fclose($fp) or die("can't close file");

5. 下載CSV文件

$sales = array(
  array('Northeast', '2004-01-01', '2004-02-01', 12.54),
  array('Northwest', '2004-01-01', '2004-02-01', 546.33),
  array('Southeast', '2004-01-01', '2004-02-01', 93.26),
  array('Southwest', '2004-01-01', '2004-02-01', 945.21),
  array('中國(guó)', '2004-01-01', '2004-02-01', 945.21),
);

$fh = fopen('php://output', 'w') or die("can't open php://output");
$total = 0;

// 告訴瀏覽器發(fā)送的是一個(gè)csv文件
header('Content-Type: application/csv');
header('Content-Disposition: attachment; filename="sales.csv"');

// 輸出表頭
fputcsv($output, array('Region', 'Start Date', 'End Date', 'Amount'));
// 輸出每一行數(shù)據(jù), 并遞增$total
foreach($sales as $sales_line){
  if(fputcsv($fh, $sales_line) === false){
    die("Can't write CSV line");  
  }else{
    $total += $sales_line[3];  
  }
}

fputcsv($fh, array('All Regions', '--', '--', $total));

fclose($fh) or die("Can't close php://output");

6.讀取CSV文件指定行和區(qū)間行

/*****讀取CSV文件中的指定行*****/
function get_file_line_a($file_name,$line){
 $n = 0;
 $handle = fopen($file_name,'r');
 if ($handle) {
  while (!feof($handle)) {
    ++$n;
    $out = fgets($handle, 4096);
    if($line==$n) break;
  }
  fclose($handle);
 }
 if( $line==$n) return $out;
 return false;
}

echo get_file_line("windows_2011_s.csv", 10);//輸入第10行內(nèi)容


/*****讀取CSV文件中的區(qū)間行*****/
function get_file_line_b( $file_name,$line_star, $line_end){
  $n = 0;
  $handle = fopen($file_name,"r");
  if ($handle) {
    while (!feof($handle)) {
      ++$n;
      $out = fgets($handle, 4096);
      if($line_star <= $n){
        $ling[] = $out;
      }
      if ($line_end == $n) break;
    }
    fclose($handle);
  }
  if( $line_end==$n) return $ling;
  return false;
}

//用 get_file_line讀取并輸出第11行到第20行

$aa = get_file_line("windows_2011_s.csv", 11, 20); //從第11行到第20行
foreach ($aa as $bb){
  echo $bb."<br>";
}

相關(guān)文章

  • CodeIgniter配置之database.php用法實(shí)例分析

    CodeIgniter配置之database.php用法實(shí)例分析

    這篇文章主要介紹了CodeIgniter配置之database.php用法,結(jié)合實(shí)例形式較為詳細(xì)的分析總結(jié)了CodeIgniter常用的數(shù)據(jù)庫(kù)連接方式,需要的朋友可以參考下
    2016-01-01
  • Windows下Apache + PHP SESSION丟失的解決過(guò)程全紀(jì)錄

    Windows下Apache + PHP SESSION丟失的解決過(guò)程全紀(jì)錄

    這篇文章主要介紹了Windows下Apache + PHP SESSION丟失的解決過(guò)程全紀(jì)錄,花費(fèi)了很長(zhǎng)時(shí)間,最終解決的方式卻令人啼笑皆非,郁悶之極。
    2015-04-04
  • thinkphp5 模型實(shí)例化獲得數(shù)據(jù)對(duì)象的教程

    thinkphp5 模型實(shí)例化獲得數(shù)據(jù)對(duì)象的教程

    今天小編就為大家分享一篇thinkphp5 模型實(shí)例化獲得數(shù)據(jù)對(duì)象的教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • 關(guān)于DISCUZ不用通行證登陸得內(nèi)容介紹

    關(guān)于DISCUZ不用通行證登陸得內(nèi)容介紹

    DISCUZ是中國(guó)最常用的論壇,雖然他本身有通行證給大家連接,但實(shí)際上用戶(hù)的統(tǒng)一還是很不好,經(jīng)常要建立兩個(gè)用戶(hù)表,第一不利于注冊(cè)和管理,第二浪費(fèi)數(shù)據(jù)庫(kù)。
    2008-10-10
  • php session_decode函數(shù)用法講解

    php session_decode函數(shù)用法講解

    在本篇文章里小編給大家整理了關(guān)于php session_decode函數(shù)怎么用的相關(guān)知識(shí)點(diǎn)以及實(shí)例內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2019-05-05
  • 在PHP中操作文件的擴(kuò)展屬性

    在PHP中操作文件的擴(kuò)展屬性

    PHP為我們提供了一個(gè)擴(kuò)展可以用于對(duì)文件的擴(kuò)展屬性進(jìn)行操作。本文通過(guò)實(shí)例代碼給大家介紹在PHP中操作文件的擴(kuò)展屬性的相關(guān)知識(shí),感興趣的朋友跟隨小編一起看看吧
    2021-07-07
  • LNMP部署laravel以及xhprof安裝使用教程

    LNMP部署laravel以及xhprof安裝使用教程

    這篇文章主要介紹了關(guān)于在LNMP上部署laravel以及xhprof安裝使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • Thinkphp5框架簡(jiǎn)單實(shí)現(xiàn)鉤子(Hook)行為的方法示例

    Thinkphp5框架簡(jiǎn)單實(shí)現(xiàn)鉤子(Hook)行為的方法示例

    這篇文章主要介紹了Thinkphp5框架簡(jiǎn)單實(shí)現(xiàn)鉤子(Hook)行為的方法,結(jié)合實(shí)例形式詳細(xì)分析了Thinkphp5框架實(shí)現(xiàn)鉤子(Hook)行為的步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2019-09-09
  • php中文驗(yàn)證碼實(shí)現(xiàn)示例分享

    php中文驗(yàn)證碼實(shí)現(xiàn)示例分享

    這篇文章主要介紹了使用php實(shí)現(xiàn)中文驗(yàn)證碼,代碼簡(jiǎn)單,大家可以直接使用
    2014-01-01
  • PHP截取發(fā)動(dòng)短信內(nèi)容的方法

    PHP截取發(fā)動(dòng)短信內(nèi)容的方法

    這篇文章主要介紹了PHP截取發(fā)動(dòng)短信內(nèi)容的方法,需要的朋友可以參考下
    2017-07-07

最新評(píng)論