Чтение данных из шаблона Excel и запись в тот же файл - PullRequest
0 голосов
/ 25 июня 2018

Я могу записать автоматизированные данные в файл Excel. Тем не менее, я прошу помощи о том, как прочитать шаблон Excel со списком имен там, где каждое имя выполняет соответствующий метод, а затем выполняет запись значений этого в строке.

Например, вот шаблон:

Шаблон Excel: Excel Template

Кроме того, вот метод, соответствующий данным в файле Excel:

public void AbbeyNational(String AbbeyNationalURL, String AN_AccCookiesButton, String AN_MortgageTabButton, String AN_ExistingCustomerButton, String AN_FollowRateButton, String AN_SVRButton, String AN_RateFld) throws InterruptedException, IOException{
    driver.get(AbbeyNationalURL);
    driver.findElement(By.xpath(AN_AccCookiesButton)).click();
    driver.findElement(By.linkText(AN_MortgageTabButton)).click();
    driver.findElement(By.xpath(AN_ExistingCustomerButton)).click();
    driver.findElement(By.xpath(AN_FollowRateButton)).click();
    driver.findElement(By.xpath(AN_SVRButton)).click();

    String a = driver.findElement(By.cssSelector(AN_RateFld)).getText();
    AN_Rate = a.substring(54,58);
    T1 = new SimpleDateFormat("dd/MM/yyyy HH:mm:ss").format(Calendar.getInstance().getTime());
    data.put("2", new Object[]{"Abbey National", AN_Rate, T1});
    System.out.println(AN_Rate);

    TakesScreenshot scrShot = (TakesScreenshot)driver;
    File srcfile = scrShot.getScreenshotAs(OutputType.FILE);
    File DestFile = new File("C:\\Users\\harpreet dugh\\Desktop\\Screenshots\\AbbeyNational.png");
    FileUtils.copyFile(srcfile, DestFile);
}

И, наконец, вот желаемый результат:

Желаемый выход: Desired Output

Чтобы уточнить, как видно из выходных данных, я хотел бы прочитать кредитору 'Abbey National' из файла excel, выполнить соответствующий метод и записать ставку и время для этого кредитора в файле excel.

Может ли кто-нибудь помочь мне с этим, пожалуйста?

1 Ответ

0 голосов
/ 25 июня 2018

Я бы предложил использовать библиотеки Apache POI для выполнения операций чтения и записи в excel.

Вам необходим HSSF для файла расширения .xls и XSSF для расширения файла .xlsx.

Я дал образец файла ExcelDataConfig. Пожалуйста, создайте отдельный класс как ExcelDataConfig.

Вы можете просто вызвать необходимые методы, создав объект ExcelDataConfig.

Для чтения и записи в вашем коде:

ExcelDataConfig config=new ExcelDataConfig(Excel Path);

//Arguments - Sheet Index, Row Number , column Number(All the index starts from 0.So, give the no of is correctly
config.getData(0,1,1)

// To write the Rate Details in Excel
config.writeData(0,1,2);

// To write the Time Details in Excel
config.writeData(0,1,3);

ExcelDataConfig класс:

public class ExcelDataConfig {

    HSSFWorkbook wb;
    HSSFSheet sheet;
    File src;

    public ExcelDataConfig(String excelPath)
    {

        src=new File(excelPath);
        try {

            FileInputStream fis=new FileInputStream(src);
            wb=new HSSFWorkbook(fis);

        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

public String getData(int sheetIndex,int row,int column){

        sheet=wb.getSheetAt(sheetIndex);
        String data="";//sheet.getRow(row).getCell(column).getStringCellValue();
        Row r=sheet.getRow(row);
        Cell c=r.getCell(column, Row.RETURN_BLANK_AS_NULL);

        if(c==null){
            data="";
        }
        else{
            if(r.getCell(column).getCellType()==HSSFCell.CELL_TYPE_STRING){
                data=r.getCell(column).getStringCellValue();                
            }else if (r.getCell(column).getCellType()==HSSFCell.CELL_TYPE_NUMERIC){
                int intData=(int) r.getCell(column).getNumericCellValue();
                data=Integer.toString(intData);
            }
        }
        return data;

    }

public void writeData(int sheetIndex,int row,int column,String content,String excelPath ) throws IOException{

        sheet=wb.getSheetAt(sheetIndex);

        sheet.getRow(row).getCell(column).setCellValue(content);
        FileOutputStream fout=new FileOutputStream(src);
        wb.write(fout);

        //wb.close();

    }

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...