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

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

jacklove
jackloveオリジナル
2018-06-22 16:03:182043ブラウズ

この記事では、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;
}

興味があるかもしれない記事:

WeChat アプレットの顔認証ログイン機能を PHP で実装

#ThinkPHP フレームワークで実装した MySQL データベースのバックアップ機能の例

PHP はフォームの繰り返し送信を防止する機能を実装します [トークン検証に基づく]

##

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

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