如何使用java

时间:2017-07-02 11:51:13

标签: java csv selenium-webdriver

在附加的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中。我是这个领域的新手,并提前致谢。

1 个答案:

答案 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

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