活着的死人 发表于 2015-2-4 00:14:13

PHP编程:PHP 数据导出到EXECEL类

在这里想谈谈自己这六个多月的PHP学习心得,希望对给比我还新的新手们有所帮助,讲的不是很深刻,甚至有的想法可能是错误的,希望不要误导新人才好,大家要有自己的主见。数据   <?
/*
    Name: ToExcel
    Author: Riyao Chen
    Version: 0.0.1
    Date: 2006-05-15
    License: GPL
*/
/****************************************
//This class is to change data from query to excel file
//SQL FORMAT:
SELECT c_id,c_title,c_subject FROM news_content WHERE c_parid=0 ORDER BY c_date desc,c_clicks desc
//The DataBase connection is open outside;
//Parameter:$sql,The query sentence ;$database,which database
***********************************/
class ToExcel
{
var $sql="";
var $fields;
var $db;

function ToExcel($sql,$database)
{
if($sql == "")
   return $this->errorMessage("NO QUERY SENTENCE!");
$this->db = $database;

//Get Table Name
$tmp=ereg_replace("SELECT.+FROM ","",$sql);
$tmp=ereg_replace("ORDER BY.+","",$tmp);
$this->table = ereg_replace(" WHERE.+","",$tmp);
//Get Fields
$field = ereg_replace("SELECT ","",$sql);
$field = ereg_replace(" FROM.+","",$field);
if(trim($field) == "*")
   $this->fields = $this->GetFieldList($this->table);//$mysql->GetFieldList($this->table);
else
   $this->fields = explode(",",$field);
   
$this->sql = $sql;

}

function ShowExcel()
{
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=Excel.xls");

//OutPut Fields Start
foreach($this->fields as $key=>$value)
{
   echo $value."\t";
   
   }
echo "\n";
//OutPut Fields End

//OutPut Field Value Start   
$result = mysql_query($this->sql);
while($row = mysql_fetch_array($result))
{
   foreach($this->fields as $key=>$value)
    echo iconv("utf-8","gb2312",$row[$value]."\t");
   echo "\n";
   }
   
//OutPut Field Value End

}

//Get The FieldLis
function GetFieldList($table)
{
if($result=mysql_list_fields($this->db,$table)){
             $i=0;
             while($i < mysql_num_fields($result)){
               $fd_names[$i]=mysql_field_name($result,$i);
               $i++;
             }
             return($fd_names);
            
         }else
            return $this->errorMessage("Unable to find any field list in table: $tbl_name");
}

function errorMessage($msg){
         echo "Error: $msg : ".mysql_error();
return false;
      }

}

/*
exemple
$sql = "SELECT * FROM news_content WHERE c_parid=0 ORDER BY c_date desc,c_clicks desc";
$excel = new ToExcel($sql,DATABASE_NAME);
$excel->ShowExcel();
*/
?>
因为函数实在是太多了,慢慢的你就会知道,知道有这个函数就可以。

分手快乐 发表于 2015-2-4 10:04:14

写js我最烦的就是 ie 和 firefox下同样的代码 结果显示的结果千差万别,还是就是最好不要用遨游去调试,因为有时候遨游是禁用js的,有可能代码是争取结果被遨游折腾的认为是代码写错。

谁可相欹 发表于 2015-2-6 15:52:26

其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎

灵魂腐蚀 发表于 2015-2-16 23:12:18

在学习的过程中不能怕麻烦,不能有懒惰的思想。学习php首先应该搭建一个lamp环境或者是wamp环境。这是学习php开发的根本。虽然网络上有很多集成的环境,安装很方便,使用起来也很稳定、

简单生活 发表于 2015-3-5 11:39:29

我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。

若相依 发表于 2015-3-8 17:59:51

真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,

再见西城 发表于 2015-3-16 08:45:59

曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线\\\\\\\'_\\\\\\\' ;

愤怒的大鸟 发表于 2015-3-19 17:32:51

先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。

飘灵儿 发表于 2015-3-21 21:37:19

小鸟是第一次发帖(我习惯潜水的(*^__^*) 嘻嘻……),有错误之处还请大家批评指正,另外,前些日子听人说有高手能用php写驱动程序,真是学无止境,人外有人,天外有天。

冷月葬花魂 发表于 2015-3-26 14:09:22

个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。

不帅 发表于 2015-3-26 22:31:15

学好程序语言,多些才是王道,写两个小时代码的作用绝对超过看一天书,这个我是深有体会(顺便还能练打字速度)。

透明 发表于 2015-4-6 09:52:51

遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。

金色的骷髅 发表于 2015-4-8 11:53:55

写的比较杂,因为我也是个新手,不当至于大家多多指正。

只想知道 发表于 2015-4-21 22:13:08

小鸟是第一次发帖(我习惯潜水的(*^__^*) 嘻嘻……),有错误之处还请大家批评指正,另外,前些日子听人说有高手能用php写驱动程序,真是学无止境,人外有人,天外有天。

小妖女 发表于 2015-5-4 12:12:57

php里的数组为空的时候是不能拿来遍历的;(这个有点低级啊,不过我刚被这个边界问题墨迹了好长一会)

再现理想 发表于 2015-5-6 01:11:22

真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,

小女巫 发表于 2015-6-17 04:59:03

php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。

老尸 发表于 2015-6-19 17:17:15

你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。

因胸联盟 发表于 2015-6-20 19:26:12

php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。

柔情似水 发表于 2015-6-28 18:57:06

开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
页: [1] 2
查看完整版本: PHP编程:PHP 数据导出到EXECEL类