仓酷云

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

[学习教程] PHP网页设计用PHP将数据导入到Foxmail

[复制链接]
海妖 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-4 00:20:01 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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

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

x
看到好的帖子最好up一下,以使得更多的人得到分享。foxmail|数据   比来小阳做了一个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不仅要掌握方法,更多的是付出汗水,我不希望看到中途放弃的人,相信自己,相信自己的选择,更要相信自己的能力,如果自己想放弃,暴力一点的话,就自己抽自己一个嘴巴。
小女巫 该用户已被删除
沙发
发表于 2015-2-7 02:37:50 | 只看该作者
php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。
愤怒的大鸟 该用户已被删除
板凳
发表于 2015-2-9 17:25:02 | 只看该作者
首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
乐观 该用户已被删除
地板
发表于 2015-2-27 12:45:53 | 只看该作者
如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域,
分手快乐 该用户已被删除
5#
发表于 2015-2-27 22:16:31 | 只看该作者
不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。
蒙在股里 该用户已被删除
6#
发表于 2015-3-2 23:37:36 | 只看该作者
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
第二个灵魂 该用户已被删除
7#
发表于 2015-3-6 00:24:17 | 只看该作者
多看优秀程序员编写的代码,仔细理解他们解决问题的方法,对自身有很大的帮助。
兰色精灵 该用户已被删除
8#
发表于 2015-3-8 14:58:22 | 只看该作者
不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。
透明 该用户已被删除
9#
发表于 2015-3-11 03:22:53 | 只看该作者
有位前辈曾经跟我说过,phper 至少要掌握200个函数 编起程序来才能顺畅点,那些不熟悉的函数记不住也要一拿手册就能找到。所以建议新手们没事就看看php的手册(至少array函数和string函数是要记牢的)。
只想知道 该用户已被删除
10#
发表于 2015-3-12 00:15:46 | 只看该作者
我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。
简单生活 该用户已被删除
11#
发表于 2015-3-13 03:31:18 | 只看该作者
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
变相怪杰 该用户已被删除
12#
发表于 2015-3-16 04:02:07 | 只看该作者
找到的的资料很多都是在论坛里的,需要注册,所以我一般没到一个论坛都注册一个id,所有的id都注册成一样的,这样下次再进来的时候就不用重复注册啦。当然有些论坛的某些资料是需要的付费的。
若相依 该用户已被删除
13#
发表于 2015-3-16 23:12:03 | 只看该作者
,熟悉html,能用div+css,还有javascript,优先考虑linux。我在开始学习的时候,就想把这些知识一起学习,我天真的认为同时学习能够互相呼应,因为知识是相通的。
精灵巫婆 该用户已被删除
14#
发表于 2015-3-19 06:00:07 | 只看该作者
我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:
活着的死人 该用户已被删除
15#
发表于 2015-3-19 20:16:39 | 只看该作者
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
因胸联盟 该用户已被删除
16#
发表于 2015-3-26 01:49:49 | 只看该作者
再就是混迹于论坛啦,咱们的phpchina的论坛就很强大,提出的问题一般都是有达人去解答的,以前的帖子也要多看看也能学到不少前辈们的经验。别的不错的论坛例如php100,javaeye也是很不错的。
山那边是海 该用户已被删除
17#
发表于 2015-4-12 01:26:34 | 只看该作者
实践是检验自己会不会的真理。
灵魂腐蚀 该用户已被删除
18#
发表于 2015-4-21 07:58:28 | 只看该作者
写的比较杂,因为我也是个新手,不当至于大家多多指正。
admin 该用户已被删除
19#
发表于 2015-5-3 22:02:55 | 只看该作者
php里的数组为空的时候是不能拿来遍历的;(这个有点低级啊,不过我刚被这个边界问题墨迹了好长一会)
深爱那片海 该用户已被删除
20#
发表于 2015-5-4 05:31:51 | 只看该作者
对于懒惰的朋友,我推荐php的集成环境xampp或者是wamp。这两个软件安装方便,使用简单。但是我还是强烈建议自己动手搭建开发环境。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-12-22 12:15

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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