0

0

用PHP将数据导入到Foxmail_PHP

php中文网

php中文网

发布时间:2016-06-01 12:32:31

|

1448人浏览过

|

来源于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文件相应的字段两端加上双引号(“即" "”)作分隔值,其间的英文逗号不作为分隔值,且字段中连续两个英文双引号(即“""”)也只作为一个显示,而不作为分隔值。

立即学习PHP免费学习笔记(深入)”;

      有了这些认识,我们就可以编写导出CSV文件的PHP文件了:

MMM金融互助系统源码
MMM金融互助系统源码

MMM金融互助系统源码是以thinkphp为核心进行开发的3m金融互助平台。程序安装说明:1.恢复数据:将“数据备份”文件夹中的 urkeji.sql 文件请采用phpMyAdmin进行导入; 2.配置Sql数据库信息,文件路径:根目录下 config.php3.后台管理地址:http://域名/admin.php 用户名:100000 密码:admin1

下载


//这一行一定要放在程序的开始地方,不能有空格或换行。因为下面的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;
  }
  ? >
  
  
  
  
  导出资料到Foxmail地址簿
   点击这里下载文件,保存并导入到您的Foxmail地址簿中。
  操作方法
  ……
  
  

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

      在Foxmail地址簿中点击“工具”-“导入”-“CSV文件”……,数据库中一大堆的资料一下子就全被导入了,这个主意还不错吧!

点击查看原图

(以上程序在Apache+PHP4+mySQL和IIS+PHP4+mySQL中皆测试通过。)

相关专题

更多
vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

26

2025.12.30

金山文档相关教程
金山文档相关教程

本专题整合了金山文档相关教程,阅读专题下面的文章了解更多详细操作。

28

2025.12.30

PS反选快捷键
PS反选快捷键

本专题整合了ps反选快捷键介绍,阅读下面的文章找到答案。

25

2025.12.30

表格中一行两行的方法
表格中一行两行的方法

本专题整合了表格中一行两行的相关教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.30

cpu温度过高解决方法大全
cpu温度过高解决方法大全

本专题整合了cpu温度过高相关教程,阅读专题下面的文章了解更多详细内容。

5

2025.12.30

ASCII码介绍
ASCII码介绍

本专题整合了ASCII码相关内容,阅读专题下面的文章了解更多详细内容。

31

2025.12.30

GPS是什么
GPS是什么

本专题整合了GPS相关内容,阅读专题下面的文章了解更多详细内容。

3

2025.12.30

wifi拒绝接入
wifi拒绝接入

本专题整合了wifi拒绝接入相关教程,阅读下面的文章了解更多详细方法。

9

2025.12.30

丰网速运介绍
丰网速运介绍

本专题整合了丰网速运查询入口以及相关内容,阅读专题下面的文章了解更多内容。

3

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

麻省理工大佬Python课程
麻省理工大佬Python课程

共34课时 | 5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号