PHP导入excel数据到MYSQL,php导入excelmysql
PHP导入excel数据到MYSQL,php导入excelmysql
这里介绍一个直接将excel文件导入mysql的例子。我花了一晚上的时间测试,无论导入简繁体都不会出现乱码,非常好用。
PHP-ExcelReader,下载地址: http://sourceforge.net/projects/phpexcelreader
说明:
测试环境:MYSQL数据库采用utf8编码.导入EXCEL文档是xls格式,经过测试,xlsx 格式[excel 2007]也OK.
文中红色标注为需要注意的地方,请替换成你配置好的数据,如数据库配置等。运行http://localost/test.php实现导入。
以下是我贴出的详细代码,其中test.php为我写的测试文件,reader.php和oleread.inc文件是从上面提供的网址中下载的。
1. test.php
代码如下:
<?<span>php </span><span>require_once</span> './includes/reader.php'<span>; </span><span>//</span><span> ExcelFile($filename, $encoding); </span> <span>$data</span> = <span>new</span><span> Spreadsheet_Excel_Reader(); </span><span>//</span><span> Set output Encoding. </span> <span>$data</span>->setOutputEncoding('gbk'<span>); </span><span>//</span><span>”data.xls”是指要导入到mysql中的excel文件 </span> <span>$data</span>->read('date.xls'<span>); @ </span><span>$db</span> = <span>mysql_connect</span>('localhost', 'root', '1234'<span>) or </span><span>die</span>("Could not connect to database.");<span>//</span><span>连接数据库 </span> <span>mysql_query</span>("set names 'gbk'");<span>//</span><span>输出中文 </span> <span>mysql_select_db</span>('wenhuaedu'); <span>//</span><span>选择数据库 </span> <span>error_reporting</span>(<span>E_ALL</span> ^ <span>E_NOTICE</span><span>); </span><span>for</span> (<span>$i</span> = 1; <span>$i</span> <= <span>$data</span>->sheets[0]['numRows']; <span>$i</span>++<span>) { </span><span>//</span><span>以下注释的for循环打印excel表数据 </span><span> /*</span><span> for ($j = 1; $j <= $data->sheets[0]['numCols']; $j++) { echo """.$data->sheets[0]['cells'][$i][$j]."","; } echo "n"; </span><span>*/</span> <span>/*</span><span> 何问起 hovertree.com </span><span>*/</span> <span>//</span><span>以下代码是将excel表数据【3个字段】插入到mysql中,根据你的excel表字段的多少,改写以下代码吧! </span> <span>$sql</span> = "INSERT INTO test VALUES('". <span>$data</span>->sheets[0]['cells'][<span>$i</span>][1]."','". <span>$data</span>->sheets[0]['cells'][<span>$i</span>][2]."','". <span>$data</span>->sheets[0]['cells'][<span>$i</span>][3]."')"<span>; </span><span>echo</span> <span>$sql</span>.'<br />'<span>; </span><span>$res</span> = <span>mysql_query</span>(<span>$sql</span><span>); </span>?>
包含的文件
OLERead.php
<?<span>php </span><span>define</span>('NUM_BIG_BLOCK_DEPOT_BLOCKS_POS', 0x2c<span>); </span><span>define</span>('SMALL_BLOCK_DEPOT_BLOCK_POS', 0x3c<span>); </span><span>define</span>('ROOT_START_BLOCK_POS', 0x30<span>); </span><span>define</span>('BIG_BLOCK_SIZE', 0x200<span>); </span><span>define</span>('SMALL_BLOCK_SIZE', 0x40<span>); </span><span>define</span>('EXTENSION_BLOCK_POS', 0x44<span>); </span><span>define</span>('NUM_EXTENSION_BLOCK_POS', 0x48<span>); </span><span>define</span>('PROPERTY_STORAGE_BLOCK_SIZE', 0x80<span>); </span><span>define</span>('BIG_BLOCK_DEPOT_BLOCKS_POS', 0x4c<span>); </span><span>define</span>('SMALL_BLOCK_THRESHOLD', 0x1000<span>); </span><span>//</span><span> property storage offsets </span> <span>define</span>('SIZE_OF_NAME_POS', 0x40<span>); </span><span>define</span>('TYPE_POS', 0x42<span>); </span><span>define</span>('START_BLOCK_POS', 0x74<span>); </span><span>define</span>('SIZE_POS', 0x78<span>); </span><span>define</span>('IDENTIFIER_OLE', <span>pack</span>("CCCCCCCC",0xd0,0xcf,0x11,0xe0,0xa1,0xb1,0x1a,0xe1<span>)); </span><span>//</span><span>echo 'ROOT_START_BLOCK_POS = '.ROOT_START_BLOCK_POS."\n"; //echo bin2hex($data[ROOT_START_BLOCK_POS])."\n"; //echo "a="; //echo $data[ROOT_START_BLOCK_POS]; //function log </span> <span>function</span> GetInt4d(<span>$data</span>, <span>$pos</span><span>) { </span><span>$value</span> = <span>ord</span>(<span>$data</span>[<span>$pos</span>]) | (<span>ord</span>(<span>$data</span>[<span>$pos</span>+1]) << 8) | (<span>ord</span>(<span>$data</span>[<span>$pos</span>+2]) << 16) | (<span>ord</span>(<span>$data</span>[<span>$pos</span>+3]) << 24<span>); </span><span>if</span> (<span>$value</span>>=4294967294<span>) { </span><span>$value</span>=-2<span>; } </span><span>return</span> <span>$value</span><span>; } </span><span>class</span><span> OLERead { </span><span>var</span> <span>$data</span> = ''<span>; </span><span>function</span><span> OLERead(){ } </span><span>function</span> read(<span>$sFileName</span><span>){ </span><span>//</span><span> check if file exist and is readable (Darko Miljanovic) </span> <span>if</span>(!<span>is_readable</span>(<span>$sFileName</span><span>)) { </span><span>$this</span>->error = 1<span>; </span><span>return</span> <span>false</span><span>; } </span><span>$this</span>->data = @<span>file_get_contents</span>(<span>$sFileName</span><span>); </span><span>if</span> (!<span>$this</span>-><span>data) { </span><span>$this</span>->error = 1<span>; </span><span>return</span> <span>false</span><span>; } </span><span>//</span><span>echo IDENTIFIER_OLE; //echo 'start'; </span> <span>if</span> (<span>substr</span>(<span>$this</span>->data, 0, 8) !=<span> IDENTIFIER_OLE) { </span><span>$this</span>->error = 1<span>; </span><span>return</span> <span>false</span><span>; } </span><span>$this</span>->numBigBlockDepotBlocks = GetInt4d(<span>$this</span>->data,<span> NUM_BIG_BLOCK_DEPOT_BLOCKS_POS); </span><span>$this</span>->sbdStartBlock = GetInt4d(<span>$this</span>->data,<span> SMALL_BLOCK_DEPOT_BLOCK_POS); </span><span>$this</span>->rootStartBlock = GetInt4d(<span>$this</span>->data,<span> ROOT_START_BLOCK_POS); </span><span>$this</span>->extensionBlock = GetInt4d(<span>$this</span>->data,<span> EXTENSION_BLOCK_POS); </span><span>$this</span>->numExtensionBlocks = GetInt4d(<span>$this</span>->data,<span> NUM_EXTENSION_BLOCK_POS); </span><span>/*</span><span> echo $this->numBigBlockDepotBlocks." "; echo $this->sbdStartBlock." "; echo $this->rootStartBlock." "; echo $this->extensionBlock." "; echo $this->numExtensionBlocks." "; </span><span>*/</span> <span>//</span><span>echo "sbdStartBlock = $this->sbdStartBlock\n"; </span> <span>$bigBlockDepotBlocks</span> = <span>array</span><span>(); </span><span>$pos</span> =<span> BIG_BLOCK_DEPOT_BLOCKS_POS; </span><span>//</span><span> echo "pos = $pos"; </span> <span>$bbdBlocks</span> = <span>$this</span>-><span>numBigBlockDepotBlocks; </span><span>if</span> (<span>$this</span>->numExtensionBlocks != 0<span>) { </span><span>$bbdBlocks</span> = (BIG_BLOCK_SIZE - BIG_BLOCK_DEPOT_BLOCKS_POS)/4<span>; } </span><span>for</span> (<span>$i</span> = 0; <span>$i</span> < <span>$bbdBlocks</span>; <span>$i</span>++<span>) { </span><span>$bigBlockDepotBlocks</span>[<span>$i</span>] = GetInt4d(<span>$this</span>->data, <span>$pos</span><span>); </span><span>$pos</span> += 4<span>; } </span><span>for</span> (<span>$j</span> = 0; <span>$j</span> < <span>$this</span>->numExtensionBlocks; <span>$j</span>++<span>) { </span><span>$pos</span> = (<span>$this</span>->extensionBlock + 1) *<span> BIG_BLOCK_SIZE; </span><span>$blocksToRead</span> = <span>min</span>(<span>$this</span>->numBigBlockDepotBlocks - <span>$bbdBlocks</span>, BIG_BLOCK_SIZE / 4 - 1<span>); </span><span>for</span> (<span>$i</span> = <span>$bbdBlocks</span>; <span>$i</span> < <span>$bbdBlocks</span> + <span>$blocksToRead</span>; <span>$i</span>++<span>) { </span><span>$bigBlockDepotBlocks</span>[<span>$i</span>] = GetInt4d(<span>$this</span>->data, <span>$pos</span><span>); </span><span>$pos</span> += 4<span>; } </span><span>$bbdBlocks</span> += <span>$blocksToRead</span><span>; </span><span>if</span> (<span>$bbdBlocks</span> < <span>$this</span>-><span>numBigBlockDepotBlocks) { </span><span>$this</span>->extensionBlock = GetInt4d(<span>$this</span>->data, <span>$pos</span><span>); } } </span><span>/*</span><span> 何问起 hovertree.com </span><span>*/</span> <span>//</span><span> var_dump($bigBlockDepotBlocks); // readBigBlockDepot </span> <span>$pos</span> = 0<span>; </span><span>$index</span> = 0<span>; </span><span>$this</span>->bigBlockChain = <span>array</span><span>(); </span><span>for</span> (<span>$i</span> = 0; <span>$i</span> < <span>$this</span>->numBigBlockDepotBlocks; <span>$i</span>++<span>) { </span><span>$pos</span> = (<span>$bigBlockDepotBlocks</span>[<span>$i</span>] + 1) *<span> BIG_BLOCK_SIZE; </span><span>//</span><span>echo "pos = $pos"; </span> <span>for</span> (<span>$j</span> = 0 ; <span>$j</span> < BIG_BLOCK_SIZE / 4; <span>$j</span>++<span>) { </span><span>$this</span>->bigBlockChain[<span>$index</span>] = GetInt4d(<span>$this</span>->data, <span>$pos</span><span>); </span><span>$pos</span> += 4<span> ; </span><span>$index</span>++<span>; } } </span><span>//</span><span>var_dump($this->bigBlockChain); //echo '=====2'; // readSmallBlockDepot(); </span> <span>$pos</span> = 0<span>; </span><span>$index</span> = 0<span>; </span><span>$sbdBlock</span> = <span>$this</span>-><span>sbdStartBlock; </span><span>$this</span>->smallBlockChain = <span>array</span><span>(); </span><span>while</span> (<span>$sbdBlock</span> != -2<span>) { </span><span>$pos</span> = (<span>$sbdBlock</span> + 1) *<span> BIG_BLOCK_SIZE; </span><span>for</span> (<span>$j</span> = 0; <span>$j</span> < BIG_BLOCK_SIZE / 4; <span>$j</span>++<span>) { </span><span>$this</span>->smallBlockChain[<span>$index</span>] = GetInt4d(<span>$this</span>->data, <span>$pos</span><span>); </span><span>$pos</span> += 4<span>; </span><span>$index</span>++<span>; } </span><span>$sbdBlock</span> = <span>$this</span>->bigBlockChain[<span>$sbdBlock</span><span>]; } </span><span>//</span><span> readData(rootStartBlock) </span> <span>$block</span> = <span>$this</span>-><span>rootStartBlock; </span><span>$pos</span> = 0<span>; </span><span>$this</span>->entry = <span>$this</span>->__readData(<span>$block</span><span>); </span><span>/*</span><span> while ($block != -2) { $pos = ($block + 1) * BIG_BLOCK_SIZE; $this->entry = $this->entry.substr($this->data, $pos, BIG_BLOCK_SIZE); $block = $this->bigBlockChain[$block]; } </span><span>*/</span> <span>//</span><span>echo '==='.$this->entry."==="; </span> <span>$this</span>-><span>__readPropertySets(); } </span><span>function</span> __readData(<span>$bl</span><span>) { </span><span>$block</span> = <span>$bl</span><span>; </span><span>$pos</span> = 0<span>; </span><span>$data</span> = ''<span>; </span><span>while</span> (<span>$block</span> != -2<span>) { </span><span>$pos</span> = (<span>$block</span> + 1) *<span> BIG_BLOCK_SIZE; </span><span>$data</span> = <span>$data</span>.<span>substr</span>(<span>$this</span>->data, <span>$pos</span>,<span> BIG_BLOCK_SIZE); </span><span>//</span><span>echo "pos = $pos data=$data\n"; </span> <span>$block</span> = <span>$this</span>->bigBlockChain[<span>$block</span><span>]; } </span><span>return</span> <span>$data</span><span>; } </span><span>function</span><span> __readPropertySets(){ </span><span>$offset</span> = 0<span>; </span><span>//</span><span>var_dump($this->entry); </span> <span>while</span> (<span>$offset</span> < <span>strlen</span>(<span>$this</span>-><span>entry)) { </span><span>$d</span> = <span>substr</span>(<span>$this</span>->entry, <span>$offset</span>,<span> PROPERTY_STORAGE_BLOCK_SIZE); </span><span>$nameSize</span> = <span>ord</span>(<span>$d</span>[SIZE_OF_NAME_POS]) | (<span>ord</span>(<span>$d</span>[SIZE_OF_NAME_POS+1]) << 8<span>); </span><span>$type</span> = <span>ord</span>(<span>$d</span><span>[TYPE_POS]); </span><span>//</span><span>$maxBlock = strlen($d) / BIG_BLOCK_SIZE - 1; </span> <span>$startBlock</span> = GetInt4d(<span>$d</span>,<span> START_BLOCK_POS); </span><span>$size</span> = GetInt4d(<span>$d</span>,<span> SIZE_POS); </span><span>$name</span> = ''<span>; </span><span>for</span> (<span>$i</span> = 0; <span>$i</span> < <span>$nameSize</span> ; <span>$i</span>++<span>) { </span><span>$name</span> .= <span>$d</span>[<span>$i</span><span>]; } </span><span>$name</span> = <span>str_replace</span>("\x00", "", <span>$name</span><span>); </span><span>$this</span>->props[] = <span>array</span><span> ( </span>'name' => <span>$name</span>, 'type' => <span>$type</span>, 'startBlock' => <span>$startBlock</span>, 'size' => <span>$size</span><span>); </span><span>if</span> ((<span>$name</span> == "Workbook") || (<span>$name</span> == "Book"<span>)) { </span><span>$this</span>->wrkbook = <span>count</span>(<span>$this</span>->props) - 1<span>; } </span><span>if</span> (<span>$name</span> == "Root Entry"<span>) { </span><span>$this</span>->rootentry = <span>count</span>(<span>$this</span>->props) - 1<span>; } </span><span>//</span><span>echo "name ==$name=\n"; </span> <span>$offset</span> +=<span> PROPERTY_STORAGE_BLOCK_SIZE; } } </span><span>function</span><span> getWorkBook(){ </span><span>if</span> (<span>$this</span>->props[<span>$this</span>->wrkbook]['size'] <<span> SMALL_BLOCK_THRESHOLD){ </span><span>//</span><span> getSmallBlockStream(PropertyStorage ps) </span> <span>$rootdata</span> = <span>$this</span>->__readData(<span>$this</span>->props[<span>$this</span>->rootentry]['startBlock'<span>]); </span><span>$streamData</span> = ''<span>; </span><span>$block</span> = <span>$this</span>->props[<span>$this</span>->wrkbook]['startBlock'<span>]; </span><span>//</span><span>$count = 0; </span> <span>$pos</span> = 0<span>; </span><span>while</span> (<span>$block</span> != -2<span>) { </span><span>$pos</span> = <span>$block</span> *<span> SMALL_BLOCK_SIZE; </span><span>$streamData</span> .= <span>substr</span>(<span>$rootdata</span>, <span>$pos</span>,<span> SMALL_BLOCK_SIZE); </span><span>$block</span> = <span>$this</span>->smallBlockChain[<span>$block</span><span>]; } </span><span>return</span> <span>$streamData</span><span>; }</span><span>else</span><span>{ </span><span>$numBlocks</span> = <span>$this</span>->props[<span>$this</span>->wrkbook]['size'] /<span> BIG_BLOCK_SIZE; </span><span>if</span> (<span>$this</span>->props[<span>$this</span>->wrkbook]['size'] % BIG_BLOCK_SIZE != 0<span>) { </span><span>$numBlocks</span>++<span>; } </span><span>if</span> (<span>$numBlocks</span> == 0) <span>return</span> ''<span>; </span><span>//</span><span>echo "numBlocks = $numBlocks\n"; //byte[] streamData = new byte[numBlocks * BIG_BLOCK_SIZE]; //print_r($this->wrkbook); </span> <span>$streamData</span> = ''<span>; </span><span>$block</span> = <span>$this</span>->props[<span>$this</span>->wrkbook]['startBlock'<span>]; </span><span>//</span><span>$count = 0; </span> <span>$pos</span> = 0<span>; </span><span>//</span><span>echo "block = $block"; </span> <span>while</span> (<span>$block</span> != -2<span>) { </span><span>$pos</span> = (<span>$block</span> + 1) *<span> BIG_BLOCK_SIZE; </span><span>$streamData</span> .= <span>substr</span>(<span>$this</span>->data, <span>$pos</span>,<span> BIG_BLOCK_SIZE); </span><span>$block</span> = <span>$this</span>->bigBlockChain[<span>$block</span><span>]; } </span><span>//</span><span>echo 'stream'.$streamData; </span> <span>return</span> <span>$streamData</span><span>; } } } </span>?>
参考:http://hovertree.com/h/bjaf/to3l3tjm.htm
http://www.cnblogs.com/roucheng/p/phpmysql.html

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









完全ガイド: PHP 拡張機能 PHPExcel を使用して Excel ファイルを処理する方法 はじめに: Excel ファイルは、大量のデータや統計分析を処理する際のデータの保存と交換のための一般的な形式としてよく使用されます。 PHP 拡張機能 PHPExcel を使用すると、Excel ファイルの読み取り、書き込み、変更を簡単に行うことができ、Excel データを効果的に処理できます。この記事では、PHP 拡張機能 PHPExcel を使用して Excel ファイルを処理する方法とコード例を紹介します。 1.PHPExcをインストールする

デジタル時代の到来により、データは私たちの日常生活や仕事において最も重要な部分となり、Excel ファイルはデータ処理のための重要なツールの 1 つになりました。 PHP開発者の多くは仕事でデータ処理や操作でExcelファイルを使用する場面に遭遇することが多いと思います。この記事では、PHPExcelライブラリを使ってExcelファイルを加工する方法と注意点を紹介します。 PHPエクセルとは何ですか? PHPExcel は PHP クラスです

PHPEXCEL は、Excel ファイルの読み書きのための優れた PHP クラス ライブラリであり、PHP を使用して Excel ファイルを読み書きできるようにする非常に十分な API を提供します。場合によっては、Excel ファイルを CSV ファイルに変換して使用する必要があることがあります。そこで、この記事ではPHPEXCELクラスライブラリを使ってExcelファイルをCSVファイルに変換して開く方法を中心に説明します。

PHPExcel は、Microsoft Excel ファイルを処理するためのオープン ソースの PHP ライブラリであり、Excel ファイルの読み取り、作成、変更、保存ができます。これは、データ分析、レポート生成、データのインポートとエクスポートなどのタスクを処理するために使用できる、強力で高度にカスタマイズ可能なツールです。この記事では、なぜ PHPExcel が PHP 開発者の間で注目されているのかを紹介します。

PHPExcel は、Microsoft Excel (.xls および .xlsx) ファイルを処理するためのオープンソース PHP ライブラリです。 Excel ファイルの読み取り、書き込み、操作が可能で、豊富な関数とメソッドを提供します。 PHP プロジェクトで PHPExcel ライブラリを使用すると、Excel ファイルを迅速かつ簡単に処理し、データのインポート、エクスポート、データ処理などの機能を実装できます。この記事では、PHPExcelを使ってExcelファイルを加工する方法を紹介します。 1. PHPExcel をインストールするには、次を使用します。

今日の急速な情報転送の時代では、データの処理とストレージの重要性がますます高まっています。 Excel テーブルはさまざまなデータを統合でき、簡単に分析および処理できるため、多くの人にとって Excel テーブルの使用が最初の選択肢になります。 Excel テーブルの作成をより効率的に完了するには、PHP と PHPExcel という 2 つの強力なツールを使用できます。この記事では、PHPとPHPExcelを使ってExcelファイルを作成する方法を紹介します。 1. まず PHPExcel をインストールします

PHP 開発のヒント: PHPExcel と PHPExcel_IOFactory を使用して MySQL データベースを操作する方法 概要: Web 開発では、Excel ファイルの処理は一般的かつ重要なタスクです。 PHPExcel は、Excel ファイルの読み書きに役立つ強力で使いやすい PHP ライブラリです。この記事では、MySQL データベースを操作するための PHPExcel および PHPExcel_IOFactory ライブラリを使用する方法を紹介します。ステップ1

PHP開発スキル:PHPExcelを使ったMySQLデータベースの操作方法 インターネットの発展に伴い、データベースには大量のデータが格納され、インポート、エクスポート、加工などの操作が必要になります。 PHP 開発において、PHPExcel は、Excel ファイルとの対話を簡素化し、データのインポートとエクスポートを実現できる強力なライブラリです。この記事では、PHPExcelを使ってMySQLデータベースを操作し、データのインポート・エクスポート機能を実装する方法を紹介します。 PHPExcelのインストールと設定
