在附加的csv图像中,我试图获取数据并根据第一列中的测试用例名称存储它的hashmap。在第二列中,我给出了rowcount值,该值表示可用于该特定测试用例的测试数据的数量,因此我可以获取rowcount的值并将其循环多次以获得该特定测试用例的所有可用数据。我编写了代码来获取rowcount的值。但我不知道如何获取该特定测试的数据并将其存储在hashmap中。
Click here to view CSV File Image
String path = "./TestData.csv";
String TestCaseName="Login";
String CurrentLine;
try (BufferedReader br = new BufferedReader(new FileReader(path))) {
while ((CurrentLine = br.readLine()) != null) {
String Data[] = CurrentLine.split(",");
if(TestCaseName.equalsIgnoreCase(Data[0])){
System.out.println("Details in this row :"+ " " +CurrentLine);
String rowcount_value = Data[1];
System.out.println(rowcount_value);
}
}
}
catch (IOException e) {
e.printStackTrace();
}
在附加的csv图像中,我想获取Testcase Login的数据,所以我在上面的代码中给出了Testcase名称作为Login。现在我想获取属于Login testcase的图像中的所有突出显示的数据并将其存储在hashmap中。上面的代码只给出了传递的测试用例名称的rowcount值。
请帮我抓取那些突出显示的数据并将其存储在hashmap中。我是这个领域的新手,并提前致谢。
答案 0 :(得分:0)
由于您的csv文件针对不同的测试用例具有固定数量的数据点,因此如果添加更多测试用例,您可能需要更新以下代码。
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
public class ReadCsv {
public static void main(String[] args) {
String path = "sample.csv";
// String TestCaseName="Login";
String CurrentLine;
//Map to store TestCase -> Map(Key ->value)
Map<String,Map<String,String>> testcaseMap = new HashMap<String,Map<String,String>>();
try (BufferedReader br = new BufferedReader(new FileReader(path))) {
br.readLine();
while ((CurrentLine = br.readLine()) != null) {
String Data[] = CurrentLine.trim().split(",");
String testCase_DataNames = "";
for(int j=2;j<Data.length;j++){
testCase_DataNames = testCase_DataNames +"_"+Data[j];
}
int dataCount = Integer.parseInt(Data[1]);
Map<String,String> testdata = new HashMap<String,String>();
for(int i=0;i<dataCount;i++){
String nextLine = br.readLine();
String feilds[] = nextLine.trim().split(",");
testdata.put(feilds[2], feilds.length ==4 ? feilds[3]:null);
}
testcaseMap.put(Data[0]+testCase_DataNames, testdata);
/*if(TestCaseName.equalsIgnoreCase(Data[0])){
System.out.println("Details in this row :"+ " " +CurrentLine);
String rowcount_value = Data[1];
System.out.println(rowcount_value);
} */
}
for(Map.Entry<String,Map<String,String>> entry:testcaseMap.entrySet()){
String key[] = entry.getKey().split("_");
System.out.println("Test case for:"+key[0]);
for(Map.Entry<String, String> dataPair: entry.getValue().entrySet()){
System.out.println("Data header:"+key[1]+" with value:"+dataPair.getKey());
if(dataPair.getValue()!= null ) {
System.out.println("Data header:"+key[2]+" with value:"+dataPair.getValue());
}
}
}
}
catch (IOException e) {
e.printStackTrace();
}
}
}
输出:
Test case for:Login
Data header:UserName with value:uname2
Data header:Password with value:pwd2
Data header:UserName with value:uname1
Data header:Password with value:pwd1
Test case for:Hotel
Data header:HotelNames with value:Ambur
Data header:HotelNames with value:BlackPerl
Data header:HotelNames with value:Zingro
希望这对你有用!祝你好运