仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 2603|回复: 20
打印 上一主题 下一主题

[学习教程] PHP网页编程之用PHP将数据导入到Foxmail的完成代码

[复制链接]
变相怪杰 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-16 00:24:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
理解动态语言的概念,运做机制,熟悉PHP语法   比来小阳做了一个PHP同窗录,同窗们本人在那边添加或修正姓名、邮箱、OICQ等信息,并保留在mySQL数据库里。某日小阳俄然想到,假如能用PHP生成一个文件,供同窗们下载并把这些材料导入他们的Foxmail地址簿中,那该多好啊!

说干就干,很快小阳便将这功效推出来了。那是若何完成的呢?这里仅以导出姓名、邮箱和OICQ三项予以申明。

  要材料可以导入Foxmail地址簿,固然要先懂得一下导入Foxmail地址簿的文件内容和格局。翻开Foxmail4.2一个帐户的地址簿,在其菜单栏“东西”-“导入”中可以看到,Foxmail撑持两种内部文件的导入:“CSV文件”和“Wab文件”。咱们选择生成CSV文件。那末可以导入Foxmail的CSV文件的内容和格局若何呢?让咱们先从Foxmail导出一个CSV文件看一下。在Foxmail地址簿当选择一个纪录不为空的文件夹,履行“东西”-“导出”- “文本文件”,保留文件名为“TEMP.CSV”, 在“下一步”的“请选择输入字段”当选择“姓名”、“电子邮箱地址”和“OICQ”,点击“完成”后便在指定途径生成了“TEMP.CSV”文件了。假如你装了微软office系列,会发明这是一个用EXCEL默许翻开的文件,实践上它是EXCEL的逗号分隔值文件,双击翻开后,其界面如图所示。

  

                               
登录/注册后可看大图


  咱们在这类情形下仍是没法晓得它的写入格局的。将“TEMP.CSV”文件改成用记事本翻开,即可以发明它的格局十分复杂:如图,文件第一行是Foxmail地址簿的字段,其它行是字段对应的值,各字段和值用英文逗号分隔。所以咱们在PHP中按这类格局生成CSV文件,他人就能够下载并导入他们的Foxmail中了!

  

                               
登录/注册后可看大图

不外还有一个成绩需求处理,那就是既然文件中以逗号作为分隔值,假如数据库纪录中有英文逗号(注:以下符号若无出格申明皆指英文符号)怎样办?固然你可以先将数据中的逗号交换为中文逗号,但其实还有一个办法,那就是假如CSV文件响应的字段两头加上双引号(“即" "”)作分隔值,其间的英文逗号不作为分隔值,且字段中一连两个英文双引号(即“""”)也只作为一个显示,而不作为分隔值。
  有了这些熟悉,咱们就能够编写导出CSV文件的PHP文件了:
复制代码 代码以下:
<? //这一行必定要放在法式的入手下手中央,不克不及有空格或换行。由于上面的header()函数不答应在利用前向用户输入任何器材。
$dfname="tofoxmail.csv"; //生成的文件名
//毗连mySQL数据库:
mysql_connect("localhost","yourname","yourpassword") or die("不克不及毗连数据库!");
mysql_select_db("alumni") or die("数据库产生毛病!");
if($action=="downit"){
$getdata=mysql_query("SELECT name,email,oicq FROM classdata"); //选择数据表中指定纪录
//假如没有材料,则:
if(@mysql_num_rows($getdata)==0){
echo "对不起,还没有任何材料!";
exit;
}
//以下生成一个文件供下载:
header("Content-disposition: filename=$dfname");
header("Content-type: unknown/unknown");
echo "姓名,电子邮件地址,OICQ,foxaddrID"; //输入第一行,Foxmail地址簿的字段
$i=1;
while($row=mysql_fetch_array($getdata)){ //获得数据类型的值
//将数据中每个双引号交换为两个:
$row[name]=str_replace("\"","\"\"",$row[name]);
$row[email]=str_replace("\"","\"\"",$row[email]);
$row[oicq]=str_replace("\"","\"\"",$row[oicq]);
//输入响应字段对应的值的行,每一个值用双引号和逗号作分隔符:
echo base64_decode("DQo=")."\"$row[name]\",\"$row[email]\",\"$row[oicq]\",$i";
/*上式中“base64_decode("DQo=")”是换行符,之所以不必“\n”,是由于二者不完整不异,
用后者将能够招致Foxmail导入掉败。
*/
$i++;
}
exit;
}
?>
<!--假如不是点击了下载的链接,则显示以下HTML内容-->
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>导出材料到Foxmail地址簿</title></head>
<body> 点击<a href="javascript:this.location=this.location+"?action=downit"">这里</a>下载文件,保留并导入到您的Foxmail地址簿中。<br>
<B>操作办法</B><br>
……
</body>
</html>

在办事器上运转上述PHP文件,下载回来的“tofoxmail.csv”文件用记事本翻开如图所示。

  在Foxmail地址簿中点击“东西”-“导入”-“CSV文件”……,数据库中一大堆的材料一会儿就全被导入了,这个主张还不错吧!

  


  (以上法式在Apache+PHP4+mySQL和IIS+PHP4+mySQL中皆测试经由过程。)熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_-
沙发
发表于 2015-2-16 00:50:38 | 只看该作者
这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。
小魔女 该用户已被删除
板凳
发表于 2015-2-26 17:35:11 | 只看该作者
作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。
金色的骷髅 该用户已被删除
地板
发表于 2015-2-27 13:28:00 | 只看该作者
使用 jquery 等js框架的时候,要随时注意浏览器的更新情况,不然很容易发生框架不能使用。
小女巫 该用户已被删除
5#
发表于 2015-3-4 11:28:47 | 只看该作者
在学习的过程中不能怕麻烦,不能有懒惰的思想。学习php首先应该搭建一个lamp环境或者是wamp环境。这是学习php开发的根本。虽然网络上有很多集成的环境,安装很方便,使用起来也很稳定、
山那边是海 该用户已被删除
6#
发表于 2015-3-9 16:52:19 | 只看该作者
要进行开发,搭建环境是首先需要做的事,windows下面我习惯把环境那个安装在C盘下面,因为我配的环境经常出现诡异事件,什么事都没做环境有的时候就不能用啦。
透明 该用户已被删除
7#
发表于 2015-3-17 00:09:11 | 只看该作者
本文当是我的笔记啦,遇到的问题随时填充
再现理想 该用户已被删除
8#
发表于 2015-3-23 08:12:33 | 只看该作者
有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。
admin 该用户已被删除
9#
发表于 2015-3-29 06:43:27 | 只看该作者
不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。
小妖女 该用户已被删除
10#
发表于 2015-4-7 14:20:21 | 只看该作者
如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
简单生活 该用户已被删除
11#
发表于 2015-4-22 19:20:49 | 只看该作者
这些中手常用的知识,当你把我说的这些关键字都可以熟练运用的时候,你可以选择自己
乐观 该用户已被删除
12#
发表于 2015-4-23 05:08:09 | 只看该作者
不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。
不帅 该用户已被删除
13#
发表于 2015-4-24 19:53:02 | 只看该作者
Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81
再见西城 该用户已被删除
14#
发表于 2015-5-1 09:10:34 | 只看该作者
有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。
深爱那片海 该用户已被删除
15#
发表于 2015-5-12 14:32:52 | 只看该作者
爱上php,他也会爱上你。
活着的死人 该用户已被删除
16#
发表于 2015-6-6 10:49:37 | 只看该作者
爱上php,他也会爱上你。
飘灵儿 该用户已被删除
17#
发表于 2015-6-23 21:28:40 | 只看该作者
说点我烦的低级错误吧,曾经有次插入mysql的时间 弄了300年结果老报错,其实mysql的时间是有限制的,大概是到203X年  具体的记不清啦,囧。
蒙在股里 该用户已被删除
18#
发表于 2015-7-10 21:00:36 | 只看该作者
为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。
爱飞 该用户已被删除
19#
发表于 2015-7-14 02:36:58 | 只看该作者
作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。
因胸联盟 该用户已被删除
20#
发表于 2015-7-25 01:52:21 | 只看该作者
微软最近出的新字体“微软雅黑”,虽然是挺漂亮的,不过firefox  支持的不是很好,所以能少用还是少用的好。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-5-2 06:32

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表