您可以使用从这个beanshell(= java)代码执行BeanShell Sampler/BeanShell PostProcessor/BeanShell PreProcessor。
下面的代码将读取你的文件中的所有行,然后选择一个随机:
import java.text.*;
import java.io.*;
import java.util.*;
String [] params = Parameters.split(",");
String csvTest = params[0];
String csvDir = params[0];
ArrayList strList = new ArrayList();
try {
File file = new File(System.getProperty("user.dir") + File.separator + csvDir + File.separator + csvTest);
if (!file.exists()) {
throw new Exception ("ERROR: file " + csvTest + " not found in " + csvDir + " directory.");
}
BufferedReader bufRdr = new BufferedReader(new FileReader(file));
String line = null;
while((line = bufRdr.readLine()) != null) {
strList.add(line);
}
bufRdr.close();
Random rnd = new java.util.Random();
vars.put("csvUrl",strList.get(rnd.nextInt(strList.size())));
}
catch (Exception ex) {
IsSuccess = false;
log.error(ex.getMessage());
System.err.println(ex.getMessage());
}
catch (Throwable thex) {
System.err.println(thex.getMessage());
}
然后你就可以通过变量来访问提取的URL($ {} csvUrl在这个例子中)。
我只怀疑在每次迭代时读取完整文件(如果必须在循环中执行此操作)从性能的角度来看是很好的解决方案。
有合适的解决方案吗? – 2012-05-10 16:11:47