您可以使用从BeanShell Sampler / BeanShell PostProcessor / BeanShell PreProcessor执行的这个 beanshell (= java) 代码。
以下代码将从您的文件中读取所有行,然后选择单个随机数:
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})。
从性能的角度来看,我只是怀疑在每次迭代中读取完整文件(如果你必须在循环中执行)是一个很好的解决方案。