ホームページ  >  記事  >  バックエンド開発  >  CI フレームワーク (CodeIgniter) によって実装されたデータのインポートおよびエクスポート操作

CI フレームワーク (CodeIgniter) によって実装されたデータのインポートおよびエクスポート操作

不言
不言オリジナル
2018-06-01 10:45:501639ブラウズ

この記事では、主に CI フレームワーク (CodeIgniter) によって実装されるデータのインポートおよびエクスポート操作を紹介し、CodeIgniter フレームワーク ライブラリで PHPExcel を使用してデータのインポートおよびエクスポートを実装する関連操作スキルを分析します。参照してください

この記事の例では、CI フレームワーク (CodeIgniter) によって実装されたデータのインポートおよびエクスポート操作について説明します。次のように、参照用に全員と共有します。

ライブラリ内の PHPExcel クラス (phpexcel.php) を参照します

public function excel_put(){
  //先做一个文件上传,保存文件
  $path=$_FILES['file'];
  $filePath = "uploads/".$path["name"];
  move_uploaded_file($path["tmp_name"],$filePath);
  //$data=array('B'=>'name','C'=>'pwd','D'=>'money1','E'=>'salt');
  $data=array('B'=>'name','C'=>'pid');
  $tablename='city2';//表名字
  $this->excel_fileput($filePath,$data,$tablename);
}

private function excel_fileput($filePath,$data,$tablename){
  $this->load->library("phpexcel");//ci框架中引入excel类
  $PHPExcel = new PHPExcel();
  $PHPReader = new PHPExcel_Reader_Excel2007();
  if(!$PHPReader->canRead($filePath)){
    $PHPReader = new PHPExcel_Reader_Excel5();
    if(!$PHPReader->canRead($filePath)){
      echo 'no Excel';
      return ;
    }
  }
  // 加载excel文件
  $PHPExcel = $PHPReader->load($filePath);
  // 读取excel文件中的第一个工作表
  $currentSheet = $PHPExcel->getSheet(0);
  // 取得最大的列号
  $allColumn = $currentSheet->getHighestColumn();
  // 取得一共有多少行
  $allRow = $currentSheet->getHighestRow();
  // 从第二行开始输出,因为excel表中第一行为列名
  for($currentRow = 2;$currentRow <= $allRow;$currentRow++){
    /**从第A列开始输出*/
    //echo $allColumn;
    for($currentColumn= &#39;A&#39;;$currentColumn<= $allColumn; $currentColumn++){
      $val = $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65,$currentRow)->getValue();
      //print_r($val);
      //die;
      if($currentColumn == &#39;A&#39;)
      {
        //echo $val."\t";
      }else if($currentColumn <= $allColumn){
        $data1[$currentColumn]=$val;
      }
    }
    foreach($data as $key=>$val){
      $data2[$val]=$data1[$key];
    }
    $this->db->insert($tablename,$data2);
    //print_r($data2);
    //echo "</br>";
  }
  //echo "\n";
  echo "导入成功";
}

データをエクスポートします:

public function excel_out(){
  header("Content-type:text/html");
  header("Content-Disposition:attachment;filename=123.xls");
  $array=$this->db->get("city")->result_array();
  $str="id\t"."name\t"."pid\n";
  foreach($array as $val){
    $str.=$val[&#39;id&#39;]."\t".$val[&#39;name&#39;]."\t".$val[&#39;pid&#39;]."\n";
  }
  echo $str;
}

それですこの記事は以上です、読んでいただきありがとうございました。詳細については、PHP 中国語 Web サイトを参照してください。

関連する推奨事項:

CodeIgniter フレームワーク データベースの基本操作の例

以上がCI フレームワーク (CodeIgniter) によって実装されたデータのインポートおよびエクスポート操作の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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