用PHP将数据导入到Foxmail的实现代码


Posted in PHP onSeptember 05, 2010

最近小阳做了一个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的逗号分隔值文件,双击打开后,其界面如图所示。

用PHP将数据导入到Foxmail的实现代码

我们在这种情况下还是无法知道它的写入格式的。将“TEMP.CSV”文件改为用记事本打开,便可以发现它的格式非常简单:如图,文件第一行是Foxmail地址簿的字段,其它行是字段对应的值,各字段和值用英文逗号分隔。所以我们在PHP中按这种格式生成CSV文件,别人就可以下载并导入他们的Foxmail中了!

用PHP将数据导入到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文件”……,数据库中一大堆的资料一下子就全被导入了,这个主意还不错吧!

用PHP将数据导入到Foxmail的实现代码

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

PHP 相关文章推荐
一个自定义位数的php多用户计数器代码
Mar 11 PHP
phpMyAdmin2.11.6安装配置方法
Aug 24 PHP
PHP中的函数嵌套层数限制分析
Jun 13 PHP
php安装xdebug/php安装pear/phpunit详解步骤(图)
Dec 22 PHP
重新认识php array_merge函数
Aug 31 PHP
php读取文件内容的方法汇总
Jan 24 PHP
php+mysqli预处理技术实现添加、修改及删除多条数据的方法
Jan 30 PHP
PHP结合jQuery插件ajaxFileUpload实现异步上传文件实例
Aug 17 PHP
php实现的debug log日志操作类实例
Jul 12 PHP
PHP 文件上传限制问题
Sep 01 PHP
PHP 计算两个时间段之间交集的天数示例
Oct 24 PHP
PHP常见的序列化与反序列化操作实例分析
Oct 28 PHP
提高PHP编程效率的53个要点(经验小结)
Sep 04 #PHP
队列在编程中的实际应用(php)
Sep 04 #PHP
php生成随机密码的三种方法小结
Sep 04 #PHP
PHP安全技术之 实现php基本安全
Sep 04 #PHP
小文件php+SQLite存储方案
Sep 04 #PHP
PHP中文件上传的一个问题
Sep 04 #PHP
PHP程序员面试 切忌急功近利(更需要注重以后的发展)
Sep 01 #PHP
You might like
也谈php网站在线人数统计
2008/04/09 PHP
php操作xml
2013/10/27 PHP
微信公众平台实现获取用户OpenID的方法
2015/04/15 PHP
PHP的Yii框架中使用数据库的配置和SQL操作实例教程
2016/03/17 PHP
PHP的Json中文处理解决方案
2016/09/29 PHP
详解Yii实现分页的两种方法
2017/01/14 PHP
Extjs 几个方法的讨论
2010/01/28 Javascript
$.get获取一个文件的内容示例代码
2013/09/11 Javascript
jquery $.fn $.fx是什么意思有什么用
2013/11/04 Javascript
jQuery表格插件datatables用法总结
2014/09/05 Javascript
基于jQuery实现仿淘宝套餐选择插件
2015/03/04 Javascript
js控制文本框只输入数字和小数点的方法
2015/03/10 Javascript
socket.io学习教程之基础介绍(一)
2017/04/29 Javascript
详解微信小程序 通过控制CSS实现view隐藏与显示
2017/05/24 Javascript
js断点调试心得分享(必看篇)
2017/12/08 Javascript
微信小程序实现批量倒计时功能
2020/11/01 Javascript
[00:32]DOTA2上海特级锦标赛 COL战队宣传片
2016/03/04 DOTA
Mac OS X10.9安装的Python2.7升级Python3.3步骤详解
2013/12/04 Python
Python的subprocess模块总结
2014/11/07 Python
使用C语言来扩展Python程序和Zope服务器的教程
2015/04/14 Python
在Python中使用base64模块处理字符编码的教程
2015/04/28 Python
itchat接口使用示例
2017/10/23 Python
python实现猜单词小游戏
2020/05/22 Python
利用Python读取txt文档的方法讲解
2018/06/23 Python
python 判断矩阵中每行非零个数的方法
2019/01/26 Python
PyQt弹出式对话框的常用方法及标准按钮类型
2019/02/27 Python
python实现密码验证合格程序的思路详解
2020/06/01 Python
基于python爬取梨视频实现过程解析
2020/11/09 Python
python工具快速为音视频自动生成字幕(使用说明)
2021/01/27 Python
耐克美国官网:Nike.com
2016/08/01 全球购物
Perfume’s Club意大利官网:欧洲美妆电商
2019/05/03 全球购物
英国独特家具和家庭用品购物网站:Cuckooland
2020/08/30 全球购物
园艺师求职信
2014/03/10 职场文书
班主任寄语大全
2014/04/04 职场文书
golang在GRPC中设置client的超时时间
2021/04/27 Golang
angular4实现带搜索的下拉框
2022/03/25 Javascript