當前位置:首頁 » 數據倉庫 » phpexcel導入資料庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

phpexcel導入資料庫

發布時間: 2023-05-11 00:34:19

『壹』 求關於php excel導入大數據到mysql的解決辦法

下載 PHPExcel

require_once('./PHPExcel/IOFactory.php');
$filePath='D:/xxx.xlsx';//excel文件名
$objReader=newPHPExcel_Reader_Excel2007();//具體查看(Documentation/Examples/Reader/exampleReader01.php)
$objPHPExcel=$objReader->羨轎load($filePath);
$sheetData=$objPHPExcel->getActiveSheet()->toArray(null,true,true,true);
$insql='insertinto表名(x,x,x)valeus';
//遍歷數組$sheetData
//如果有標題兄游肆先刪除磨差unset($sheetData[1]);
foreach($sheetDataas$k=>$data){
$insql.='('.$data['A'].','.$data['B'].','.$data['C'].'),';
//一次插入100條數據減少資料庫壓力
if(($k+1/100)==0){
$insql=rtrim($insql,',').';';//將最後的逗號替換成分好
//插入資料庫並且重置字元串$insql
//或者保存到文件中利用source命令插入資料庫
}
}

『貳』 thinkPHP3.2使用phpexcel導入文件到資料庫

這是我寫過的,絕對能用,不行你再找我!!

<?php
if($_POST[sub]){

$uptypes=array('application/vnd.ms-excel','application/octet-stream'碰謹蘆);
$max_file_szie=20*pow(2,20); //上傳的文件小於20MB
$destination_folder='../conn/'; //上傳文件保存路徑
if($_SERVER['REQUEST_METHOD']=='POST'){
if(!is_uploaded_file($_FILES['upfile']['tmp_name'])){

exit("<script> alert('文件不存在!');history.back();</script>");
}
if($max_file_szie<$_FILES['upfile']['size']){

exit("<script> alert('文件太大了!');history.back();</script>");
}
if(!in_array($_FILES['upfile']['type'],$uptypes)){
echo '文件類型不符合!'.$_FILES['upfile']['type'];
exit("<script> alert('文件類型不符合!');history.back();</script>");

}
if(!file_exists($destination_folder)){
mkdir($destination_folder);
}
$filename=$_FILES['upfile']['tmp_name'];
$image_size=getimagesize($filename);
$pinfo=pathinfo($_FILES['upfile'晌咐]['name']); //文件路徑信息
$ftype=$pinfo['extension']; //舊文件後綴名
$destination = $destination_folder.$_FILES['upfile']['name']; //新文件名稱

if(file_exists($destination)&&$voerwrie !=true){

exit("<script> alert('同名文件已經存在了!');history.back();</script>");

}
//把上傳的文件從臨時文件夾移動到指定目錄
if(!move_uploaded_file($filename,$destination)){

exit("<script> alert('移動文件出錯了!');history.back();</script>");
}
$pinfo=pathinfo($destination);
$fname=$pinfo[basename];
$tpfile=$destination;//上傳文件名

//-----------上傳成功,導入數據star-----

$dataf=$tpfile;
if(!file_exists($dataf))
{
exit("文件不存在"); //文件不存在

}

$file = fopen("$dataf",'r');

while ($d = fgetcsv($file)) { //每次讀取CSV裡面的一行內容
//print_r($d); //此為一個數組,要獲得每一個數據,訪問數組下標即可
$type="`uid`='$d[0]' && name='$d[1]'";
$dsql=dbst($tableqz.message2,$type);

if(!$dsql){
$uid=trim($d[0]); //編號
$name=trim($d[1]); //客戶名稱
$type="(`uid`, `username`, `password`) VALUES (NULL, '$uid', '$name');";
dbin(hh_members,$type);
}
}

fclose($file);
unlink("$dataf");

}

//---上傳end

exit("<script>笑帶 alert('成功導入了所有數據!');history.back();</script>");
}
?>

『叄』 thinkphp PHPExcel導入到資料庫,但是沒有數據,插入的數據全是空白的。求解答

用PHPExcel,PHPExcel是相當強大的 MS Office Excel 文檔生成類庫空鉛。

你上它的官/網把程序包下/載下來,裡面有 PHPExcel 的程序、還有30個實常式序和三個斗告好文友瞎檔。
看一下其中的開發文檔你就會用了。

讀取(這段在開發文檔里有的,在13頁):
require_once '../Classes/PHPExcel/IOFactory.php';

$objReader = PHPExcel_IOFactory::createReader('Excel2007');
$objReader->setReadDataOnly(true);

$objPHPExcel = $objReader->load("test.xlsx");
$objWorksheet = $objPHPExcel->getActiveSheet();

echo '<table>' . "\n";
foreach ($objWorksheet->getRowIterator() as $row) {
echo '<tr>' . "\n";
$cellIterator = $row->getCellIterator();
$cellIterator->setIterateOnlyExistingCells(false);
foreach ($cellIterator as $cell) {
echo '<td>' . $cell->getValue() . '</td>' . "\n";
}
echo '</tr>' . "\n";
}
echo '</table>' . "\n";
?>

『肆』 thinkphp3.1中的phpexcel導入怎麼用

首先,去PHPExcel官方網站下載PHPExcel,官方地址為;http://phpexcel.codeplex.com/.我下的是1.8.0版本的.解壓後發現還是蠻大的,有十幾M,不知道其他版本是不是會小點.
這里寫圖片描述
把解壓好的PHPExcel文件放在ThinkPHP的Vender文件夾下(專門放第三方類庫的),如下圖
這里寫圖片描述
其次,創建Excel轉換數組類,並把它放在ThinkPHP\Extend\Library\ORG\Util目錄下
class ExcelToArrary {
public function __construct() {
Vendor("PHPExcel.Classes.PHPExcel");//引入phpexcel類(留意路徑,不了解路徑可以查看下手冊)
Vendor("PHPExcel.Classes.PHPExcel.IOFactory"); //引入phpexcel類(留意路徑)
}
public function read($filename,$encode,$file_type){
if(strtolower ( $file_type )=='xls')//判斷excel表類型為2003還是2007
{
Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel5"); //引入phpexcel類(留意路徑)
$objReader = PHPExcel_IOFactory::createReader('Excel5');
}elseif(strtolower ( $file_type )=='xlsx')
{
Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel2007");//引入phpexcel類(留意路徑)
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
}
$objReader->setReadDataOnly(true);
$objPHPExcel = $objReader->load($filename);
$objWorksheet = $objPHPExcel->getActiveSheet();
$highestRow = $objWorksheet->getHighestRow();
$highestColumn = $objWorksheet->getHighestColumn();
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
$excelData = array();
for ($row = 1; $row <= $highestRow; $row++) {
for ($col = 0; $col < $highestColumnIndex; $col++) {
$excelData[$row][] =(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
}
}
return $excelData;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
如右圖這里寫圖片描述
現在來說Excel,表格的結構樣式和MySQL樣式要類似,表格樣式如下(本人對Excel使用只是一般,所以如果有Excel大神做的報表,不知後果如何).
這里寫圖片描述
前端頁面相關代碼:
<div>
<form method="post" action="{:U('Index/upload')}" enctype="multipart/form-data">
<font>導入Excel數據:</font>
<label for="file_stu">上傳</label>
<input name="file_stu" type="file" id="file_stu" />
<h3>溫馨提示:</h3>
<p>請確認您的Excel表格類型是xls的,以免出現兼容問題.</p>
<inputtypeinputtype="submit" class="sure" value="導入" />
</form>
</div>
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
最後,控制器部分使用了Thinkphp自帶的上傳類,使用unlink()函數是為了刪除上傳的excel表格,以免文件夾存入過多文件,調試代碼時可先注釋掉.或者不寫也行,把刪除文件的工作交給你們的運維.代碼中foreach循環部分$v[]里的0, 1,2可以改動以下看看與Excel表格里的內容是什麼關系.可以把數組列印出來看一看,你就很清楚了
相關代碼:
public function upload(){
import('ORG.Util.ExcelToArrary');//導入excelToArray類
if (! empty ( $_FILES ['file_stu'] ['name'] )){
import('ORG.Net.UploadFile');
$upload = new UploadFile();// 實例化上傳類
$upload->maxSize = 3145728 ;// 設置附件上傳大小
$upload->allowExts = array('xls', 'xlsx');// 設置附件上傳類型
$upload->savePath = './Uploads/';// 設置附件上傳目錄
if(!$upload->upload()) {// 上傳錯誤提示錯誤信息
$this->error($upload->getErrorMsg());
}else{// 上傳成功 獲取上傳文件信息
$info = $upload->getUploadFileInfo();
}
}else{
$this->error('(⊙o⊙)~沒傳數據就導入?!你在逗我?!');
}
//mp($info);die;
$ExcelToArrary=new ExcelToArrary();//實例化
$res=$ExcelToArrary->read($info[0]['savepath'].$info[0]['savename'],"UTF-8",$info[0]['extension']);//傳參,判斷office2007還是office2003
$res = array_slice($res,1); //為了去掉Excel里的表頭,也就是$res數組里的$res[0];
//mp($res);
foreach ( $res as $k => $v ){ //循環excel表
$data[$k]['mobile'] = $v [0];//創建二維數組
$data[$k]['name'] = $v [1];
$data[$k]['ty'] = $v [2];
}
//mp($data);die;
$result=M('appkey')->addAll($data);
if(!$result){
$this->error('導入資料庫失敗');
exit();
}else{
$filename = './Uploads/'.$info[0]['savename'];//上傳文件絕對路徑,unlink()刪除文件函數
if (unlink($filename)) {
$this->success ( '導入成功' );
}else{
$this->error('緩存刪除失敗');
}
}
}

『伍』 PHP 用PHPExcel往資料庫導入大量數據

1、首先我們准備一個含有數據的Excel表格,表頭和數據表中的表欄位相對應。

『陸』 如何通過PHP將excel的數據導入MySQL中

在開發PHP程序時,很多時候我們會有將數據批量導入資料庫的需求,如學生信息批量添加到資料庫中,而事先用excel編排好,對excel實行操作,便是我們比較常用的選擇方式。

在對excel的操作中,phpExcelReade便是很多人的共同選擇。在具體實現中,我們可以以文件上傳方式將excel文件上傳到伺服器中的某個位置,通過以下操作將excel中的數據導入到資料庫後,在將上傳的文件刪除即可。

代碼如下:

$dir=dirname(__FILE__);//獲取當前腳本的絕對路徑
$dir=str_replace(「//」,」/」,$dir).」/」;

$filename=』uploadFile.xls';//可以定義一個上傳後的文件名稱
$result=move_uploaded_file($_FILES[『upload』][『tmp_name』],$dir.$filename);//假如上傳到當前目錄下
if($result)//如果上傳文件成功,就執行導入excel操作
{
require_once『phpExcelReader/Excel/reader.php';
$data=newSpreadsheet_Excel_Reader();
$data->setOutputEncoding(『utf-8′);//設置在頁面中輸出的編碼方式,而不是utf8

//該方法會自動判斷上傳的文件格式,不符合要求會顯示錯誤提示信息(錯誤提示信息在該方法內部)。
$data->read(「$filename」);//讀取上傳到當前目錄下名叫$filename的文件

error_reporting(E_ALL^E_NOTICE);
//如果excel表帶標題,則從$i=2開始,去掉excel表中的標題部分(要將$i<=改為指鋒$i<否則會插入一條多餘的空數據)
for($i=2;$i<$data->sheets[0][『numRows』];$i++)
{
$sql=「INSERTINTOuser(stuid,class,name,sex,classNum,tel,addr,remark)VALUES(『」.
$data->sheets[0][『cells』][$i][1].」『,'」.爛逗裂//學號
$data->sheets[0][『cells』][$i][2].」『,'」.//班級
$data->sheets[0][『cells』][$i][3].」『,'」.//姓名
$data->sheets[0][『cells』][$i][4].」『,'」.//性別
$data->sheets[0][『cells』][$i][5].」『,'」.飢閉//班內序號
$data->sheets[0][『cells』][$i][6].」『,'」.//聯系電話
$data->sheets[0][『cells』][$i][7].」『,'」.//聯系地址
$data->sheets[0][『cells』][$i][8].」『)」;//附註

$db->query($sql);
$insert_info.=」$sql</br>/n」;//可以用來顯示數據插入的信息

}
$totalNums=$data->sheets[0][『numRows』]-2;//求出導入的總數據條數(這里是減去2,才會得到去除標題後的總數據)
//echo「導入成功!」;
unlink(「$filename」);//刪除上傳的excel文件

}
else
{
$errmsg=」上傳失敗」;
}

『柒』 如何通過PHP將excel的數據導入MySQL中

准備工作: 下載PHP-ExcelReader,下載後用到\phpExcelReader\Excel目錄下的oleread.inc和reader.php兩個文件,並將reader.php文件打開後require_once 'Spreadsheet/Excel/Reader/OLERead.php';屏蔽掉,增加為require_once 'oleread.inc'; 然後直接將這兩個文件復制到伺服器下WAMP,直接復制到WWW目錄下,再將所需要的excel文件考進來我的文件是classify.xls,然後需要一個調用reader.php的文件,源代碼如下:
ExcelToMysql.php
<?php
require_once 'reader.php';
$data = new Spreadsheet_Excel_Reader();
$data->setOutputEncoding('gbk');
$data->read('classify.xls'); //」classify.xls」是指要導入到mysql中的excel文件
@ $db = mysql_connect("localhost", "root", "") or
die("Could not connect to database.");//連接資料庫
mysql_query("set names 'gbk'");//輸出中文
mysql_select_db('japlearn'); //選擇資料庫
error_reporting(E_ALL ^ E_NOTICE);

for ($i = 1; $i <= $data->sheets[0]['numRows']; $i++) {
//以下注釋的for循環列印excel表數據

//以下代碼是將excel表數據【6個欄位】插入到mysql中,根據你的excel表欄位的多少,改寫以下代碼吧!
$sql = "INSERT INTO classify VALUES('".
$data->sheets[0]['cells'][$i][1]."','".
$data->sheets[0]['cells'][$i][2]."','".
$data->sheets[0]['cells'][$i][3]."','".
$data->sheets[0]['cells'][$i][4]."','".$data->sheets[0]['cells'][$i][5]."','".$data->sheets[0]['cells'][$i][6]."')";

echo $sql.'<br />';
$res = mysql_query($sql);
}

?>
把上面代碼注釋的地方替換成自己配置好的數據,如資料庫配置等。運行本機測試地址實現導入。

『捌』 用phpexcel把excel中的數據導入到MYSQL中日期發生錯誤如何解決

授之以魚不世滲如授之以漁,我教你個思路。
步驟:
1、將一個帶有日期欄位的表導出成EXCEL文件。
2、打開EXCEL文件,查看穗返型日期的在表格中的存儲方式。
3、模仿這種存儲方式,將原來的數據修改成這種存儲方式。
4、將EXCEL進行導入MYSQL中
5、查看數據是否符合要求。
備註:可以目標表可以的日期猜猜欄位修改為varchar格式試一試。最後祝樓主工作順利。

『玖』 thinkphp怎麼把excel導入資料庫

  • thinkPHP實現將excel導入到資料庫中的方法體如下:

PHPExcel插件可點擊此處本站下載。

這里使用的是thinkphp框架的3.1版本,下載好壓縮包,框架中的extend中的vendor文件夾中新建一個名為PHPExcel的文件夾,把classes裡面的內容放到裡面

下面是前端頁面

提示:我在測試的時候遇到報錯exception 'PHPExcel_Reader_Exception' with message 'The filename

原因是由於excel的文件後綴可能不同,我的文件後綴是xlsx,然後給把他另存為了xls的文件,就可以了

<html>

<head>

</head>

<body>

<form action="{pigcms::U('Jdb/abcdefgwulisuibian')}" method="post" enctype="multipart/form-data">

<input type="file" name="import"/>

<input type="hidden" name="table" value="tablename"/>

<input type="submit" value="導入"/>

</form>

</body>

</html>


下面是php的

function abcdefgwulisuibianuplod(){

$this->display();//顯示頁面

}

function abcdefgwulisuibian(){

if (!empty($_FILES)) {

import("@.ORG.UploadFile");

$config=array(

'allowExts'=>array('xlsx','xls'),

'savePath'=>'./Public/upload/',

'saveRule'=>'time',

);

$upload = new UploadFile($config);

if (!$upload->upload()) {

$this->error($upload->getErrorMsg());

} else {

$info = $upload->getUploadFileInfo();

}

vendor("PHPExcel.PHPExcel");

$file_name=$info[0]['savepath'].$info[0]['savename'];

$objReader = PHPExcel_IOFactory::createReader('Excel5');

$objPHPExcel = $objReader->load($file_name,$encode='utf-8');

$sheet = $objPHPExcel->getSheet(0);

$highestRow = $sheet->getHighestRow(); // 取得總行數

$highestColumn = $sheet->getHighestColumn(); // 取得總列數

for($i=2;$i<=$highestRow;$i++)//這個地方根據需要,一般第一行是名稱,所以從第二行開始循環,也可以從第一行開始

{

$data['lianjieid'] = $objPHPExcel->getActiveSheet()->getCell("A".$i)->getValue();//資料庫欄位和excel列相對應

$data['yaoqingma'] = $objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue();

$data['dlmima']= $objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue();

$data['ljdi']= $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue();

M('jdb')->add($data);//插入資料庫

}

$this->success('導入成功!');

}else

{

$this->error("請選擇上傳的文件");

}

}

『拾』 如何用php實現將excel導入到資料庫中

把excel
改為
cvs文件
?
//連接資料庫文件
$connect=mysql_connect("localhost","admin","admin")
or
die("鏈接資料庫失敗!");
//連接資料庫(test)
mysql_select_db("testcg",$connect)
or
die
(mysql_error());
$temp=file("test.csv");//連接EXCEL文件,格式為了.csv
for
($i=0;$i
<count($temp);$i++)
{
$string=explode(",",$temp[$i]);//通過循環得到EXCEL文件中每行記錄的值
//將EXCEL文件中每行記錄的值插入到資料庫中
$q="insert
into
ceshi
(name,num,dom)
values('$string[0]','$string[1]','$string[2]');";
mysql_query($q)
or
die
(mysql_error());
if
(!mysql_error());
{
echo
"
成功導入數據!";
}
echo
$string[4]."\n";
unset($string);
}
?