之前印象中string与stringbuilder操作时,如果多次改变string就使用stringbuilder,效率会提高;

今天实际遇到了问题,亲身经历过之后,这性能不是一般的影响啊;不是同一个数量级的;

场景描述:

一个包含50719条记录的excel文件,读取其中的内容,通过逗号分隔的方式拼接成字符串;

如果使用string要耗时三四十分钟;有可能更长,并且耗费更多的内存;

如果使用stringbuilder只需要几秒钟;有可能更短;

测试代码如下:

使用stringbuilder
/**
* v1.1 excel转txt 输入excel流,返回txt流
* @param ins excel流
* @param filename2 txt临时文件路径
* @param split_char 分割符
* @param Column 总列数
* */
private boolean ExcelToTxt(InputStream ins, String filename2, String split_char, String Column){
boolean flag = false;
Workbook rwb = null;
FileOutputStream fops = null;
Sheet rs = null;
Cell cell = null;
String split_char_real = ",";//实际分隔符
if(split_char!=null && split_char.trim().length()>0){
split_char_real = split_char;
}
//获得文件名
//String filename1 = filename.substring(0,filename.lastIndexOf("."));
//路径+文件名+.txt后缀
//String filename2 = path+"/"+filename1+".txt";
//创建txt临时文件
File newFile = new File(filename2);
try {
//从输入流创建Workbook
rwb = Workbook.getWorkbook(ins);
//获取第一张Sheet表
rs = rwb.getSheet(0);
//获取Sheet表中所包含的总列数
int rsColumns = rs.getColumns();
if(Column!=null && Column.trim().length()>0){
rsColumns = Integer.valueOf(Column);//使用配置的列数
}
//获取Sheet表中所包含的总行数
int rsRows = rs.getRows();
//拼接内容
StringBuilder s = new StringBuilder();
for(int i=0;i<rsRows;i++){ // cell = rs.getCell(0,i);//每行的第一个
// if(cell.getContents().trim().length()==0){//如果第一列为空就结束读取excel
// break;
// }
//判断是否为空行
try {
StringBuilder rowData = new StringBuilder();
for(int j=0;j<rsColumns;j++){
cell = rs.getCell(j,i);
rowData.append(cell.getContents());
}
if (new String(rowData).trim().length() == 0) { //如果为空行,就结束读取excel
break;
}
} catch (Exception e) {
System.out.println("*****DataImport*********** 判断空行出错");
e.printStackTrace();
break;
} for(int j=0;j<rsColumns;j++){
cell = rs.getCell(j,i);
String content = cell.getContents();
s.append(content.replaceAll("\n", "") );
s.append(split_char_real);//支持换行
}
if(s.length()>0) s.delete(s.length()-split_char_real.length(),s.length());//s = s.substring(0,s.length()-split_char_real.length());
//
/*if(s.length()>0 ){
int count = StringUtils.countMatches(s, split_char_real);
//&& s.split(split_char_real).length>0 && s.split(split_char_real).length < rsColumns
s = s + split_char_real+ " ";
}*/
if(s.lastIndexOf(split_char_real) == (s.length() - split_char_real.length())){
s.append(" ");
}
if(i<rsRows-1) s.append("\r\n"); }
System.out.println("--------DataImport---------excel转换生成的txt文件内容:"+newFile.getAbsolutePath());
if(!newFile.exists()){//如果文件不存在,就创建一个新的
newFile.createNewFile();
}
fops = new FileOutputStream(newFile);//使用输出流
fops.write(s.toString().getBytes());//写入文本文件
flag = true;//转换成功
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (BiffException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally{
//操作完成时,关闭对象,释放占用的内存空间
rwb.close();
try {
fops.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return flag; } public static void main(String[] args) {
DataImport di = new DataImport();
try
{
di.ExcelToTxt(new FileInputStream("f:\\团圆行动营销成功客户上传_20140610.xls"), "f:\\2014.txt", ",", "10");
} catch (Exception e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
}
使用string
/**
* v1.1 excel转txt 输入excel流,返回txt流
* @param ins excel流
* @param filename2 txt临时文件路径
* @param split_char 分割符
* @param Column 总列数
* */
private boolean ExcelToTxt(InputStream ins, String filename2, String split_char, String Column){
boolean flag = false;
Workbook rwb = null;
FileOutputStream fops = null;
Sheet rs = null;
Cell cell = null;
String split_char_real = ",";//实际分隔符
if(split_char!=null && split_char.trim().length()>0){
split_char_real = split_char;
}
//获得文件名
//String filename1 = filename.substring(0,filename.lastIndexOf("."));
//路径+文件名+.txt后缀
//String filename2 = path+"/"+filename1+".txt";
//创建txt临时文件
File newFile = new File(filename2);
try {
//从输入流创建Workbook
rwb = Workbook.getWorkbook(ins);
//获取第一张Sheet表
rs = rwb.getSheet(0);
//获取Sheet表中所包含的总列数
int rsColumns = rs.getColumns();
if(Column!=null && Column.trim().length()>0){
rsColumns = Integer.valueOf(Column);//使用配置的列数
}
//获取Sheet表中所包含的总行数
int rsRows = rs.getRows();
//拼接内容
String s = "";
for(int i=0;i<rsRows;i++){ // cell = rs.getCell(0,i);//每行的第一个
// if(cell.getContents().trim().length()==0){//如果第一列为空就结束读取excel
// break;
// }
//判断是否为空行
try {
StringBuilder rowData = new StringBuilder();
for(int j=0;j<rsColumns;j++){
cell = rs.getCell(j,i);
rowData.append(cell.getContents());
}
if (new String(rowData).trim().length() == 0) { //如果为空行,就结束读取excel
break;
}
} catch (Exception e) {
System.out.println("*****DataImport*********** 判断空行出错");
e.printStackTrace();
break;
} for(int j=0;j<rsColumns;j++){
cell = rs.getCell(j,i);
String content = cell.getContents();
s = s + content.replaceAll("\n", "") + split_char_real;//支持换行
}
if(s.length()>0) s = s.substring(0,s.length()-split_char_real.length());
//
if(s.length()>0 && s.split(split_char_real).length>0 && s.split(split_char_real).length < rsColumns){
s = s + split_char_real+ " ";
}
if(i<rsRows-1) s = s + "\r\n"; }
System.out.println("--------DataImport---------excel转换生成的txt文件内容:"+s);
if(!newFile.exists()){//如果文件不存在,就创建一个新的
newFile.createNewFile();
}
fops = new FileOutputStream(newFile);//使用输出流
fops.write(s.getBytes());//写入文本文件
flag = true;//转换成功
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (BiffException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally{
//操作完成时,关闭对象,释放占用的内存空间
rwb.close();
try {
fops.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return flag; } public static void main(String[] args) {
DataImport di = new DataImport();
try
{
di.ExcelToTxt(new FileInputStream("f:\\团圆行动营销成功客户上传_20140610.xls"), "f:\\2014.txt", ",", "10");
} catch (Exception e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
}

java 中String与StringBuilder 效率的更多相关文章

  1. 探秘Java中String、StringBuilder以及StringBuffer

    探秘Java中String.StringBuilder以及StringBuffer 相信String这个类是Java中使用得最频繁的类之一,并且又是各大公司面试喜欢问 到的地方,今天就来和大家一起学习 ...

  2. JAVA中String和StringBuilder类的特点及使用

    转自:https://www.imooc.com/code/2202 仅做个人学习记录之用,侵删! 什么是 Java 中的字符串 在 Java 中,字符串被作为 String 类型的对象处理. Str ...

  3. java中String、StringBuilder、StringBuffer三者的区别

    在Java项目开发中,字符串是最长使用的数据类型,而有关字符串的String.StringBuilder.StringBuffer三者又常常让人分不清楚什么时候该使用哪个. 特此整理一下. Strin ...

  4. Java中String、StringBuilder以及StringBuffer

    原文出处: 海子 相信String这个类是Java中使用得最频繁的类之一,并且又是各大公司面试喜欢问到的地方,今天就来和大家一起学习一下String.StringBuilder和StringBuffe ...

  5. java中String与StringBuilder的区别

    相信大家对 String 和 StringBuffer 的区别也已经很了解了,但是估计还是会有很多同志对这两个类的工作原理有些不清楚的地方,今天我在这里重新把这个概念给大家复习一下,顺便牵出 J2SE ...

  6. java中 String StringBuffer StringBuilder的区别

    * String类是不可变类,只要对String进行修改,都会导致新的对象生成. * StringBuffer和StringBuilder都是可变类,任何对字符串的改变都不会产生新的对象. 在实际使用 ...

  7. java中String,StringBuffer,StringBuilder之间的区别

    文章转载自:http://www.cnblogs.com/frankliiu-java/archive/2010/07/05/1771537.html String是固定长度的字符串,如果要发生变化必 ...

  8. Java中String、StringBuilder和StringBuffer

    StringBuilder和StringBuffer内部都是通过char[]来实现的.(jdk1.9后,底层把char 数组变成了byte[].)唯一不同的就是我们的StringBuffer内部操作方 ...

  9. java中String、stringbuilder、stringbuffer区别

    1.可变与不可变 String类中使用字符数组保存字符串,如下就是,因为有"final"修饰符,所以可以知道string对象是不可变的.每次对String对象进行改变的时候其实都等 ...

随机推荐

  1. J2EE 课件3 JSP标记

    •JSP标记包括指令标记.动作标记和自定义标记.其中自定义标记主要讲述与Tag文件有关的Tag标记    1.指令标记page page 指令用来定义整个JSP页面的一些属性和这些属性的值,属性值用单 ...

  2. AbstractList 重写 equals() 方法

    题目内容 题目内容很简单,就是创建 ArrayList 和 Vector 集合,向两者添加相同内容的字符串,最后用 equals() 方法比较是否相等. 这里就考察了 "==" 和 ...

  3. react 单元测试 (jest+enzyme)

    为什么要做单元测试 作为一个前端工程师,我是很想去谢单元测试的,因为每天的需求很多,还要去编写测试代码,感觉时间都不够用了. 不过最近开发了一个比较复杂的项目,让我感觉一旦项目大了.复杂了,而且还是多 ...

  4. ArcGIS AO中控制图层中要素可见状态的总结

    一.DefinitionExpression 实现新建查询图层,查询结果要素为选中状态 该接口可以通过两种方法来控制要素的可见状态. 思路1 通过该接口的 DefinitionExpression 方 ...

  5. C/C++ 答疑解问

    1. sizeof(string)的大小 string属于类,类的大小就是类中成员变量(非静态)加上指向虚函数表的指针以及指向虚基类表的指针加起来的和.因为string是一个模板类,受具体的实现来决定 ...

  6. 1245 最小的N个和(前k小ai+bi)

    1245 最小的N个和  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 有两个长度为 N ...

  7. vim插件ctags的安装和使用【转】

    本文转载自:http://blog.csdn.net/g_brightboy/article/details/16830395 [ctags功能]: 为源码的变量/对象.结构体/类.函数/接口.宏等产 ...

  8. 在Struts2中ognl.MethodFailedExceptiond异常的解决办法

    问题描述: 在 Struts2 里面,当页面向服务器提交参数时报ognl.MethodFailedException:和java.lang.NoSuchMethodException:异常 异常信息  ...

  9. Linux扩展正则表达式

    1. 扩展正则表达式 1.1 +(加号) + 表示前一个字符出现1次或1次以上 1.1.1 理解+ 要求:取出文件内容连续出现的小写字母 [root@oldboyedu50-lnb /oldboy]# ...

  10. 用vue-cli快速构建项目

    用vue-cli脚手架快速构建项目的过程:1.首先要在node的环境下安装: 1>安装node:https://nodejs.org/en/(带npm,但是npm太慢了,建议安装cnpm,cnp ...