前面26/27节中已经讲了如果字符串中含有逗号及双引号时写入csv的处理方式,敲重点
如果字段中有逗号(,),该字段使用双引号(”)括起来;
如果该字段中有双引号,该双引号前要再加一个双引号,然后把该字段使用双引号括起来。
问题来了,
第一 我们从接口响应中提取出来的字符串如何判断是否含有逗号和双引号呢?
第二 如果有,字符串怎么用代码处理?之前27节中的例子是人为的在含有双引号的位置再增加了一个双引号,那实际提取出来的字符串可能每个双引号的位置不一样,那要如何加?
问题一、使用contains、indexof函数判断
假设提取的字符串为detail1,通过contains去查找是否包含所查找的字符串,结果是布尔值类型,true/false,这样d1中包含逗号,所以值为true,d1中不包含引号,所以值为false
//定义一个写入的字段
String detail1="你好,jmeter";
Boolean d1=detail1.contains(",");
Boolean d2=detail1.contains("\"");
log.info(d1.toString());
log.info(d2.toString());
另一种方法通过indexOf从左至右查找字符所在的位置,有就显示位置号,从0开始;不存在则显示-1
//定义一个写入的字段
String detail1="你好,jmeter";
//
//Boolean d1=detail1.contains(",");
//Boolean d2=detail1.contains("\"");
//log.info(d1.toString());
//log.info(d2.toString());
int d3=detail1.indexOf(",");
int d4=detail1.indexOf("\"");
log.info(d3.toString());
log.info(d4.toString());
问题二、处理这些字符串,使得写入csv文件时不会产生分列,无双引号情况
思路是
如果字段中有逗号(,),该字段使用双引号(”)括起来;
如果该字段中有双引号,该双引号前要再加一个双引号,然后把该字段使用双引号括起来。
将这段文字翻译成代码就是:
//定义一个写入csv文件的地址
String filePath1 = "D://xntest//result.csv";
//定义一个写入的字段
String detail1="你好,jmeter";
//Boolean d1=detail1.contains(",");
//Boolean d2=detail1.contains("\"");
//log.info(d1.toString());
//log.info(d2.toString());
//方法1
if(detail1.contains(","))
{
if(detail1.contains("\""))
{
//再含有双引号的位置再增加双引号
detail1=detail1.replace("\"","\"\"");
}
detail1="\""+detail1+"\"";
}
//创建写入对象
FileWriter fw=new FileWriter(filePath1,true);
BufferedWriter bw=new BufferedWriter(fw);
bw.write(detail1+"\n");
bw.flush();
fw.close();
//定义一个写入csv文件的地址
String filePath1 = "D://xntest//result.csv";
//定义一个写入的字段
String detail1="你好,jmeter";
//Boolean d1=detail1.contains(",");
//Boolean d2=detail1.contains("\"");
//log.info(d1.toString());
//log.info(d2.toString());
//方法2
if(detail1.indexOf(",")>=0)
{
if(detail1.indexOf("\"")>=0)
{
//再含有双引号的位置再增加双引号
detail1=detail1.replace("\"","\"\"");
}
detail1="\""+detail1+"\"";
}
//创建写入对象
FileWriter fw=new FileWriter(filePath1,true);
BufferedWriter bw=new BufferedWriter(fw);
bw.write(detail1+"\n");
bw.flush();
fw.close();
再来看下带逗号双引号的例子,执行更改detail1的字符串数据,我们使用方法二执行
//定义一个写入csv文件的地址
String filePath1 = "D://xntest//result.csv";
//定义一个写入的字段
String detail1="你好,\"jmeter\"呀!";
//Boolean d1=detail1.contains(",");
//Boolean d2=detail1.contains("\"");
//log.info(d1.toString());
//log.info(d2.toString());
//方法1
//if(detail1.contains(","))
//{
// if(detail1.contains("\""))
// {
// //再含有双引号的位置再增加双引号
// detail1=detail1.replace("\"","\"\"");
// }
// detail1="\""+detail1+"\"";
//}
//int d3=detail1.indexOf(",");
//int d4=detail1.indexOf("\"");
//log.info(d3.toString());
//log.info(d4.toString());
//方法2
if(detail1.indexOf(",")>=0)
{
if(detail1.indexOf("\"")>=0)
{
//再含有双引号的位置再增加双引号
detail1=detail1.replace("\"","\"\"");
}
detail1="\""+detail1+"\"";
}
//创建写入对象
FileWriter fw=new FileWriter(filePath1,true);
BufferedWriter bw=new BufferedWriter(fw);
bw.write(detail1+"\n");
bw.flush();
fw.close();