PHP导入excel数据到MYSQL mysql导入excel文件 java excel导入mysql mysql 导入excel
这里介绍一个直接将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> $data->sheets[0]['numRows']; <span>$i</span>++<span>) { </span><span>//</span><span>以下注释的for循环打印excel表数据 </span><span>/*</span><span> for ($j = 1; $j 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]) ord(<span>$data</span>[<span>$pos</span>+2]) ord(<span>$data</span>[<span>$pos</span>+3]) ); <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> $bbdBlocks; <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> $this->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> $bbdBlocks + <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> $this-><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> $this->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> $j++<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> $j++<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> strlen(<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]) ); <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> $nameSize ; <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'] SMALL_BLOCK_THRESHOLD){ <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
以上就介绍了PHP导入excel数据到MYSQL,包括了导入EXCEL,Mysql方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Laravel 是一款 PHP 框架,用于轻松构建 Web 应用程序。它提供一系列强大的功能,包括:安装: 使用 Composer 全局安装 Laravel CLI,并在项目目录中创建应用程序。路由: 在 routes/web.php 中定义 URL 和处理函数之间的关系。视图: 在 resources/views 中创建视图以呈现应用程序的界面。数据库集成: 提供与 MySQL 等数据库的开箱即用集成,并使用迁移来创建和修改表。模型和控制器: 模型表示数据库实体,控制器处理 HTTP 请求。

MySQL和phpMyAdmin是强大的数据库管理工具。1)MySQL用于创建数据库和表、执行DML和SQL查询。2)phpMyAdmin提供直观界面进行数据库管理、表结构管理、数据操作和用户权限管理。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

文章摘要:本文提供了详细分步说明,指导读者如何轻松安装 Laravel 框架。Laravel 是一个功能强大的 PHP 框架,它 упростил 和加快了 web 应用程序的开发过程。本教程涵盖了从系统要求到配置数据库和设置路由等各个方面的安装过程。通过遵循这些步骤,读者可以快速高效地为他们的 Laravel 项目打下坚实的基础。

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

MySQL和MariaDB的主要区别在于性能、功能和许可证:1.MySQL由Oracle开发,MariaDB是其分支。2.MariaDB在高负载环境中性能可能更好。3.MariaDB提供了更多的存储引擎和功能。4.MySQL采用双重许可证,MariaDB完全开源。选择时应考虑现有基础设施、性能需求、功能需求和许可证成本。

文章首段摘要:在选择开发 Yi 框架应用程序的软件时,需要考虑多个因素。虽然原生移动应用程序开发工具(如 XCode 和 Android Studio)可以提供强大的控制和灵活性,但跨平台框架(如 React Native 和 Flutter)凭借其编写一次,即可部署到多个平台的优点而越来越受欢迎。对于刚接触移动开发的开发者,低代码或无代码平台(如 AppSheet 和 Glide)可以快速轻松地构建应用程序。另外,云服务提供商(如 AWS Amplify 和 Firebase)提供了全面的工具

SQL是一种用于管理关系数据库的标准语言,而MySQL是一个使用SQL的数据库管理系统。SQL定义了与数据库交互的方式,包括CRUD操作,而MySQL实现了SQL标准并提供了额外的功能,如存储过程和触发器。
