用PHP将数据导入到Foxmail


Posted in PHP onOctober 09, 2006

最近小阳做了一个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文件了:

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

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

用PHP将数据导入到Foxmail

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

PHP 相关文章推荐
PHP安装问题
Oct 09 PHP
mysql_fetch_row,mysql_fetch_array,mysql_fetch_assoc的区别
Apr 24 PHP
PHP开发环境配置(MySQL数据库安装图文教程)
Apr 28 PHP
PHP array_multisort()函数的使用札记
Jul 03 PHP
Smarty的配置与高级缓存技术分享
Jun 05 PHP
PHP5中Cookie与 Session使用详解
Apr 30 PHP
PHP FTP操作类代码( 上传、拷贝、移动、删除文件/创建目录)
May 10 PHP
PHP小技巧之函数重载
Jun 02 PHP
thinkphp缓存技术详解
Dec 09 PHP
判断、添加和删除WordPress置顶文章的相关PHP函数小结
Dec 10 PHP
PHP共享内存用法实例分析
Feb 12 PHP
PHP模拟post提交数据方法汇总
Feb 16 PHP
PHP 中的一些经验积累
Oct 09 #PHP
详细介绍PHP应用提速面面观
Oct 09 #PHP
基于PHP与XML的PDF文档生成技术
Oct 09 #PHP
利用js调用后台php进行数据处理原码
Oct 09 #PHP
PHP初学者头疼问题总结
Oct 09 #PHP
php代码优化及php相关问题总结
Oct 09 #PHP
PHP数据库开发知多少
Oct 09 #PHP
You might like
怎样辨别一杯好咖啡
2021/03/03 新手入门
php实现根据IP地址获取其所在省市的方法
2015/04/30 PHP
很多人都是用下面的js刷新站IP和PV
2008/09/05 Javascript
parseInt parseFloat js字符串转换数字
2010/08/01 Javascript
jQuery代码优化 遍历篇
2011/11/01 Javascript
javascript的switch用法注意事项分析
2015/02/02 Javascript
全面解析Javascript无限添加QQ好友原理
2016/06/15 Javascript
JavaScript如何实现跨域请求
2016/08/05 Javascript
js 判断各种数据类型的简单方法(推荐)
2016/08/29 Javascript
总结Javascript中数组各种去重的方法
2016/10/04 Javascript
浅谈pc端rem字体设置的问题
2017/08/03 Javascript
bootstrap paginator分页插件的两种使用方式实例详解
2017/11/14 Javascript
AngularJS实现的2048小游戏功能【附源码下载】
2018/01/03 Javascript
vue数据控制视图源码解析
2018/03/28 Javascript
详解webpack运行Babel教程
2018/06/13 Javascript
微信小程序scroll-view实现字幕滚动
2018/07/14 Javascript
layui 选择列表,打勾,点击确定返回数据的例子
2019/09/02 Javascript
微信小程序关键字变色实现代码实例
2019/12/13 Javascript
Vue点击切换Class变化,实现Active当前样式操作
2020/07/17 Javascript
Javascript 模拟mvc实现点餐程序案例详解
2020/12/24 Javascript
Queue 实现生产者消费者模型(实例讲解)
2017/11/13 Python
解决python3捕获cx_oracle抛出的异常错误问题
2018/10/18 Python
Python类的继承用法示例
2019/01/31 Python
Python获取数据库数据并保存在excel表格中的方法
2019/06/12 Python
tensorflow 自定义损失函数示例代码
2020/02/05 Python
python中format函数如何使用
2020/06/22 Python
美国一家主打母婴用品的团购网站:zulily
2017/09/19 全球购物
英国建筑用品在线:Building Supplies Online(BSO)
2018/04/30 全球购物
世界领先的豪华床上用品供应商之一:Bedeck Home
2019/03/18 全球购物
WebSphere 应用服务器都支持哪些认证
2013/12/26 面试题
青年标兵事迹材料
2014/08/16 职场文书
2014年校务公开工作总结
2014/12/18 职场文书
Django项目如何正确配置日志(logging)
2021/04/29 Python
Python 如何将integer转化为罗马数(3999以内)
2021/06/05 Python
Java内存模型之happens-before概念详解
2021/06/13 Java/Android
JavaScript 定时器详情
2021/11/11 Javascript