用PHP将数据导入到Foxmail

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中皆测试通过。)

时间: 2024-11-03 21:43:54

用PHP将数据导入到Foxmail的相关文章

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

最近小阳做了一个PHP同学录,同学们自己在那里添加或修改姓名.邮箱.OICQ等信息,并保存在mySQL数据库里.某日小阳突然想到,如果能用PHP生成一个文件,供同学们下载并把这些资料导入他们的Foxmail地址簿中,那该多好啊! 说干就干,很快小阳便将这功能推出来了.那是如何实现的呢?这里仅以导出姓名.邮箱和OICQ三项予以说明. 要资料可以导入Foxmail地址簿,当然要先了解一下导入Foxmail地址簿的文件内容和格式.打开Foxmail4.2一个帐户的地址簿,在其菜单栏"工具"-

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

最近小阳做了一个PHP同学录,同学们自己在那里添加或修改姓名.邮箱.OICQ等信息,并保存在mySQL数据库里.某日小阳突然想到,如果能用PHP生成一个文件,供同学们下载并把这些资料导入他们的Foxmail地址簿中,那该多好啊! 说干就干,很快小阳便将这功能推出来了.那是如何实现的呢?这里仅以导出姓名.邮箱和OICQ三项予以说明. 要资料可以导入Foxmail地址簿,当然要先了解一下导入Foxmail地址簿的文件内容和格式.打开Foxmail4.2一个帐户的地址簿,在其菜单栏"工具"-

如何将Outlook邮件导入到Foxmail

  1打开Outlook,点击"工具"--"选项". 2在"选项"面板中,我们选择"邮件设置"中的"数据文件". 3在弹出的"数据文件"面板中,我们选择"打开文件夹". 4这样就找到了我们Outlook的数据文件,请大家务必记住该文件的存放位置. 导入到Foxmail1下面在"百度搜索"Foxmail安装程序,安装完成后打开Foxmail. 2点击

eclipse-谁知道用JSP展现数据库里面数据导入导出功能怎样写的代码?

问题描述 谁知道用JSP展现数据库里面数据导入导出功能怎样写的代码? 做数据导出老导不出数据,我想知道是不是数据库方法错误,谁知道用JSP展现数据库里面数据导入导出功能怎样写的代码? 解决方案 导入导出EXCEL数据http://yangbobestone.iteye.com/blog/1123458

使用sql*loader进行数据导入

数据 环境说明: 数据库:Oracle8.1.6OEM; 系  统:Windows2000 Server.*******************************************************************************************用记事本创建控制文件input.ctl,内容如下: load datainfile 'test.txt'  --数据文件append into table Testfields terminated by '|'

活用DW的数据导入、排序与美化

排序|数据 有的时候,我们经常需要把客户信息等一些资料发布到网上以便联系,但是随着客户资料的越来越多,你的网上更新是不是也觉得越来越力不从心了呢?这该怎么办?其实,除了用asp.php等这些后台语言来实现快捷更新外,dreamweaver本身就提供了数据导入与排序的方法,这对不懂后台的朋友绝对是个大大的福音.dw也从版本3到最新的mx一直都保留了该功能,可见它的实用之处.下面我们就来见识一下它的功效究竟如何.注:本文以dreameaver MX为例 1. 例如我们现在手头有个kehu.txt文件

将Excel数据导入Access数据库

access|excel|数据|数据库 将Excel数据导入Access数据库   最近,有一些网友常常问到关于Execl数据库操作的问题,其中不少是关于"Excel数据导入Access "的问题.至于将Execl数据导入Access的方法有两种:一种是直接导入法:另一种是建立连接法.而我们在日常工作中用的最多的是直接导入法,限于篇幅,我这里就只讲直接导入法,希望能给大家带来参考. 具体操作可以按以下步骤进行: 1. 启动Microsoft Access2000: 2.  建立一个空数

MySQL数据导入导出方法与工具介绍(1- myslqimport utility)

mysql|数据             MySQL数据导入导出方法与工具介绍(1- myslqimport utility)              mysqlimport文本文件导入工具介绍 翻译声明:    本文内容来自Sam's Teach Yourself MySQL in 21 Days一书的部分内容,by Mark Maslakowski      英文原文版权属原作者所有,中文的部分翻译有略有增删;原书讲的过于清楚的地方有删,讲的不清楚的地方有增:如果有翻译的不妥或者不正确的地

MySQL数据导入导出方法与工具介绍(2-import from sql files)

mysql|数据    MySQL数据导入导出方法与工具介绍(2-import from sql files)          批处理导入文件,从sql文件导入数据到数据库中 翻译声明:    本文内容来自Sam's Teach Yourself MySQL in 21 Days一书的部分内容,by Mark Maslakowski    英文原文版权属原作者所有,中文的部分翻译有略有增删;原书讲的过于清楚的地方有删,讲的不清楚的地方有增:如果有翻译的不妥或者不正确的地方,请指正. 翻译者:D