gpt4 book ai didi

java - 如何使用java根据第一列名称从csv文件获取数据

转载 作者:太空宇宙 更新时间:2023-11-04 11:21:17 25 4
gpt4 key购买 nike

在附加的 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 图像中,我想获取测试用例登录的数据,因此我在上面的代码中将测试用例名称指定为登录。现在我想获取属于登录测试用例的图像中所有突出显示的数据并将其存储在 HashMap 中。上面的代码只是给出了传递的测试用例名称的 rowcount 值。

请帮我获取那些突出显示的数据并将其存储在 HashMap 中。我是这个领域的新手,提前致谢。

最佳答案

由于您的 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

希望这对您有用!祝你好运

关于java - 如何使用java根据第一列名称从csv文件获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44870505/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com