java 本excel 通讯录 文件批量生成 .vcf文件, .csv文件批量生成 .vcf

本人原博客:https://www.iteye.com/blog/user/mr-lili-1986-163-com  更多文章,后期将转过来

package test2;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;

import org.apache.commons.lang3.text.translate.UnicodeEscaper;
import org.apache.commons.lang3.text.translate.UnicodeUnescaper;
import org.apache.http.client.utils.URLEncodedUtils;

/**

*// 个人原 iteye博客:http://mr-lili-1986-163-com.iteye.com/
* excel 文件 (必须是 , 隔开的 记事本文件) 批量生成 .vcf文件
* @author Administrator
*
*/
public class Test {

public static void main(String[] args) throws UnsupportedEncodingException {
//E99988E5BF97E6988E

String filePath = "D:\\cone\\WLMContacts.csv";
// "res/";
List<String> list = readTxtFile(filePath);
System.out.println("-------------------");
if(null != list && list.size() > 0){
for (String str : list) {
String[] ts = str.split(",");
String name = ts[0];
String tel = ts[2];
String org = ts[1];
printConnectstr(name, tel, org);
}
}

// String s = "陈志";
// String name = "陈小明2";
// String tel = "13564576688";
// String org = "市场部";
//
// printConnectstr(name, tel, org);

// System.out.println(s+" --的unicode编码是:"+gbEncoding(s));
// System.out.println(gbEncoding(s) + " --转换成中文是:"+decodeUnicode(gbEncoding(s)));

}

/**
* 打印格式
* @param name
* @param tel
* @param org
*/
private static void printConnectstr(String name, String tel, String org) {
System.out.println("BEGIN:VCARD");
System.out.println("VERSION:2.1");
String n1 = getURLEncoderString(name);
System.out.println("N;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:;"+n1+";;;");
System.out.println("FN;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:"+n1);
System.out.println("TEL;CELL:"+tel);
System.out.println("ORG:");
String org1 = getURLEncoderString(org);
System.out.println("TITLE;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:"+org1);
System.out.println("END:VCARD");
}

/**
* 读cvs“ ,隔开的文件 ”文件
* @param filePath
* @return
*/
public static List<String> readTxtFile(String filePath){
List list = new ArrayList<String>();
try {

String encoding="GBK";
File file=new File(filePath);
if(file.isFile() && file.exists()){ //判断文件是否存在
InputStreamReader read = new InputStreamReader(
new FileInputStream(file),encoding);//考虑到编码格式
BufferedReader bufferedReader = new BufferedReader(read);
String lineTxt = null;

while((lineTxt = bufferedReader.readLine()) != null){
System.out.println(lineTxt);

list.add(lineTxt);
}
read.close();
}else{
System.out.println("找不到指定的文件");
}
} catch (Exception e) {
System.out.println("读取文件内容出错");
e.printStackTrace();
}
return list;

}

/**
* 转成手机码
* @param str
* @return
*/
public static String getURLEncoderString(String str) {
String result = "";
if (null == str) {
return "";
}
try {
result = java.net.URLEncoder.encode(str, "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
String c2 = result.replaceAll("%", "=");//转换成手机通讯艮编码格式
return c2;
}

/**
* 解码
* @param str
* @return
*/
public static String URLDecoderString(String str) {
String result = "";
if (null == str) {
return "";
}
try {
result = java.net.URLDecoder.decode(str, "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return result;
}

// /*
// * 中文转unicode编码
// */
// public static String gbEncoding(final String gbString) {
// char[] utfBytes = gbString.toCharArray();
// String unicodeBytes = "";
// for (int i = 0; i < utfBytes.length; i++) {
// String hexB = Integer.toHexString(utfBytes[i]);
// if (hexB.length() <= 2) {
// hexB = "00" + hexB;
// }
// unicodeBytes = unicodeBytes + "\\u" + hexB;
// }
// return unicodeBytes;
// }
// /*
// * unicode编码转中文
// */
// public static String decodeUnicode(final String dataStr) {
// int start = 0;
// int end = 0;
// final StringBuffer buffer = new StringBuffer();
// while (start > -1) {
// end = dataStr.indexOf("\\u", start + 2);
// String charStr = "";
// if (end == -1) {
// charStr = dataStr.substring(start + 2, dataStr.length());
// } else {
// charStr = dataStr.substring(start + 2, end);
// }
// char letter = (char) Integer.parseInt(charStr, 16); // 16进制parse整形字符串。
// buffer.append(new Character(letter).toString());
// start = end;
// }
// return buffer.toString();
// }

}

------------------------------------------------------

测试文件内容格式:记事本,以,隔开就行

张小格,办公会领导,13412422268
刘小明,事业部,18587456548
张磊,事业部,15954270846

ORG:代表的就是部门

生成格式,与导入  手机 的vcf 一致,生成后,可直接导入手机,   下面是两个事例生成的字符串结构

BEGIN:VCARD
VERSION:2.1
N;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:;=E4=BB=98=E5=8D=8E=E8=8C=82;;;
FN;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:=E4=BB=98=E5=8D=8E=E8=8C=82
TEL;CELL:13250345128
ORG:
TITLE;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:=E4=B8=AD=E5=BF=83=E9=A2=86=E5=AF=BC
END:VCARD
BEGIN:VCARD
VERSION:2.1
N;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:;=E5=88=98=E5=AE=8F;;;
FN;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:=E5=88=98=E5=AE=8F
TEL;CELL:13250345128
ORG:
TITLE;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:=E5=92=A8=E8=AF=A2=E4=BA=8B=E4=B8=9A=E9=83=A8
END:VCARD

java通讯录 批量生成 .vcf文件, .csv文件批量生成 .vcf,手机自动导入相关推荐

  1. excel文件批量转换格式为csv文件,并合并成一个csv

    一.excel文件批量转换格式为csv文件 1. 打开一个Excel工具,查看菜单中是否有[开发工具],如果没有,需要手动添加该工具.具体步骤如下,通过[文件]->[选项],弹出Excel选项对 ...

  2. 一个生成Rockwell RSLogix5000 .csv 文件和.L5X文件的Excel插件

    一个生成Rockwell RSLogix5000 .csv 文件和.L5X文件的Excel插件 不知道各位AB PLC工程师花多少时间和精力在重复性的编程工作上.比如模拟量输入输出的处理,模拟量报警, ...

  3. Python——dat文件批量合并为同一个csv文件

    Python--dat文件批量合并为同一个csv文件 目的:将文件夹ZW下的所有dat文件(含子文件夹)合并,并保存到results.csv中,便于后续使用excel进行处理与分析. 代码: #!/u ...

  4. 随机生成数字写入csv文件

    随机生成数字写入csv文件 import csv #导入csv库 import random #导入random库,用来随机生成数字f = open('csv文件/number.csv', 'w+', ...

  5. 随机生成姓名写入csv文件

    随机生成姓名写入csv文件 import csv import random #导入random模块f = open('csv文件/name2.csv', 'w+', encoding='gbk', ...

  6. wince 下生成excel可人文件CSV文件

    wince下不支持直接写入EXCEL文件,数据有需要后期在PC端采用ExCEL处理这是就需要使用CSV文件了它是文本形式的文件可已通过程序写文本文件生成,同时CSV文件有是ExCEL也可以识别的文件可 ...

  7. java 数据转成xml_java转换CSV文件生成xml格式数据

    注册CSDN快六个月了,之前一直是看园子里的文章,或者碰到问题时,进来查点资料,今天终于决定写一篇自己在园子里的blog. 好吧,鉴于水平太菜,就只记录过程,其中原理啥的并不是很明晰,所以此blog只 ...

  8. php页面导出csv,使用PHP生成并导出CSV文件

    CSV文件是以纯文本形式存储的,一般以逗号为分隔符. 这里主要简单介绍下如何导出CSV文件. 一.浏览器导出CSV文件格式 /** * 导出CSV文件 */ function exportCsv() ...

  9. java使用poi将excel转csv文件(所有sheet页、值)

    java使用poi将excel中每一个sheet页中数据转为csv文件 其中空单元格值为null,并去掉了转csv时数字等默认加上的小数点 使用jar包版本: poi-3.8 xmlbeans-3.1 ...

  10. PHP进行生成并且导出CSV文件

    1.参考 https://www.cnblogs.com/woods1815/p/11875913.html 2.基础 CSV文件是以纯文本形式存储的,一般以逗号为分隔符 3.浏览器导出CSV文件格式 ...

最新文章

  1. CENTOS6.4 IBUS输入法不显示候选词解决办法
  2. spark sql 上个月_SPARK-SQL内置函数之时间日期类
  3. 【Android View事件分发机制】滑动冲突
  4. pthread_join
  5. jqgrid ajax reload,jqgrid“reloadGrid”动作后将数据重新加载到文本框
  6. 10 非受控组件以及受控与非受控的选择方案
  7. LeetCode 340. 至多包含 K 个不同字符的最长子串(滑动窗口)
  8. 事件图谱是什么?它能预测未来吗?
  9. 详解Spring框架的AOP机制
  10. 理性看待计算机专业,理性看待西电优研政策!本校计算机考研党须知
  11. mysql error 28,MySQL错误:Got error 28 from storage engine
  12. HttpClient 使用指南 - POST篇
  13. ai人工智能可以干什么_人工智能可以解决我的业务问题吗?
  14. 3.使用SqlCommand执行SQL语句
  15. c语言计算机二级知识点总结,计算机二级考试C语言知识点总结
  16. 威联通服务器操作系统,QNAP 威联通 453BT3 网络存储服务器 使用手记,Nas中的小钢炮...
  17. 开源项目:羚羊-抖音运营平台,基于Vue+抖音开放平台+小白开放平台+PhalApi开源框架的抖音运营管理平台
  18. “止于至善,彼岸可及”——记我在东大的这三年
  19. 微信公众号代运营的的技巧有哪些(2)
  20. 树莓派蓝牙连接就断开

热门文章

  1. windows进程管理小工具procexp.exe查找恶意插件
  2. 用户需求规格说明书模板,介绍
  3. css参考-img标签
  4. Gof 设计模式 完结
  5. robocode java_如何建造你的第一个Java Robocode?
  6. 使用proteus8.9进行跑马灯程序仿真
  7. 六款Linux常用远程连接工具介绍
  8. SQL——正则表达式
  9. 基于html的2048小游戏,基于jQuery的2048小游戏设计(网页版)
  10. 查看/统计 代码行数