Como ler/gravar dados de arquivo Excel: Selenium POI

File IO é uma parte crítica de qualquer processo de software. Freqüentemente criamos um arquivo, abrimos e atualizamos algo ou excluímos em nossos computadores. O mesmo acontece com Selenium Automation. Precisamos de um processo para manipular arquivos com Selenium.

Java nos fornece diferentes classes para manipulação de arquivos com Selenium. Neste tutorial, aprenderemos como podemos ler e escrever em sobressair arquivo com a ajuda de Java Pacote IO e apache Biblioteca de POIs.

Apache POI em Selênio

A Apache POI em Selênio é uma API amplamente usada para testes baseados em dados de selênio. É uma biblioteca POI escrita em Java que fornece aos usuários uma API para manipular Microsoft documentos como .xls e .xlsx. Os usuários podem criar, modificar e ler/gravar facilmente em arquivos Excel. POI significa “Implementação de ofuscação deficiente”.

Exportando Excel

Como lidar com arquivo Excel usando POI (Maven POM Dependency)

Lidar com arquivo Excel usando POI

Para ler e escrever arquivos Excel em Java, o Apache fornece uma biblioteca POI muito famosa. Esta biblioteca é capaz o suficiente para ler e escrever ambos XLS e XLSX formato de arquivo do Excel.

Ler XLS arquivos, um HSSF a implementação é fornecida pela biblioteca POI.

Ler XLSX, XSSFGenericName implementação de POI biblioteca será a escolha. Vamos estudar essas implementações em detalhes.

Se você estiver usando Maven em seu projeto, a dependência do Maven será

Lidar com arquivo Excel usando POI

<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.1.1</version>
</dependency>

Ou você pode simplesmente baixar a versão mais recente dos frascos de POI em http://poi.apache.org/download.html & baixe o arquivo zip mais recente

Lidar com arquivo Excel usando POI

Ao baixar o arquivo zip deste jar, você precisa descompactá-lo e adicionar todos esses jars ao caminho de classe do seu projeto.

Lidar com arquivo Excel usando POI

Classes e interfaces em POI

Classes e interfaces no Apache POI
Classes e interfaces no Apache POI

Following é uma lista de diferentes interfaces e classes Java em POI para ler XLS e XLSX Arquivo-

  • livro: As classes XSSFWorkbook e HSSFWorkbook implementam esta interface.
  • Pasta de Trabalho XSSF: é uma representação de classe do arquivo XLSX.
  • Pasta de trabalho HSSF: é uma representação de classe do arquivo XLS.
  • segurança: As classes XSSFSheet e HSSFSheet implementam esta interface.
  • Folha XSSF: é uma classe que representa uma planilha em um arquivo XLSX.
  • Folha HSSF: é uma classe que representa uma planilha em um arquivo XLS.
  • Linha: As classes XSSFrow e HSSFrow implementam esta interface.
  • XSFRow: é uma classe que representa uma linha na planilha do arquivo XLSX.
  • HSSFrow: é uma classe que representa uma linha na planilha do arquivo XLS.
  • Célula: As classes XSSFCell e HSSFCell implementam esta interface.
  • Célula XSSF: é uma classe que representa uma célula em uma linha do arquivo XLSX.
  • Célula HSSF: É uma classe que representa uma célula em uma linha do arquivo XLS.

Operação de leitura/gravação

Para nosso exemplo, consideraremos abaixo o formato de arquivo Excel fornecido

Operação de leitura e gravação

Ler dados do arquivo Excel

Exemplo completo: Aqui estamos tentando ler dados do Excel no Selenium:

package excelExportAndFileIO;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ReadGuru99ExcelFile {

    public void readExcel(String filePath,String fileName,String sheetName) throws IOException{

    //Create an object of File class to open xlsx file

    File file =    new File(filePath+"\\"+fileName);

    //Create an object of FileInputStream class to read excel file

    FileInputStream inputStream = new FileInputStream(file);

    Workbook guru99Workbook = null;

    //Find the file extension by splitting file name in substring  and getting only extension name

    String fileExtensionName = fileName.substring(fileName.indexOf("."));

    //Check condition if the file is xlsx file

    if(fileExtensionName.equals(".xlsx")){

    //If it is xlsx file then create object of XSSFWorkbook class

    guru99Workbook = new XSSFWorkbook(inputStream);

    }

    //Check condition if the file is xls file

    else if(fileExtensionName.equals(".xls")){

        //If it is xls file then create object of HSSFWorkbook class

        guru99Workbook = new HSSFWorkbook(inputStream);

    }

    //Read sheet inside the workbook by its name

    Sheet guru99Sheet = guru99Workbook.getSheet(sheetName);

    //Find number of rows in excel file

    int rowCount = guru99Sheet.getLastRowNum()-guru99Sheet.getFirstRowNum();

    //Create a loop over all the rows of excel file to read it

    for (int i = 0; i < rowCount+1; i++) {

        Row row = guru99Sheet.getRow(i);

        //Create a loop to print cell values in a row

        for (int j = 0; j < row.getLastCellNum(); j++) {

            //Print Excel data in console

            System.out.print(row.getCell(j).getStringCellValue()+"|| ");

        }

        System.out.println();
    } 

    }  

    //Main function is calling readExcel function to read data from excel file

    public static void main(String...strings) throws IOException{

    //Create an object of ReadGuru99ExcelFile class

    ReadGuru99ExcelFile objExcelFile = new ReadGuru99ExcelFile();

    //Prepare the path of excel file

    String filePath = System.getProperty("user.dir")+"\\src\\excelExportAndFileIO";

    //Call read file method of the class to read data

    objExcelFile.readExcel(filePath,"ExportExcel.xlsx","ExcelGuru99Demo");

    }

}

Observação: não estamos usando o Teste quadro aqui. Execute a classe como aplicativo Java usando a função read excel no Selenium conforme mostrado no exemplo acima.

Ler dados do arquivo Excel

Gravar dados em arquivo Excel

Exemplo completo: aqui estamos tentando gravar dados do arquivo Excel adicionando uma nova linha no arquivo Excel

package excelExportAndFileIO;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class WriteGuru99ExcelFile {

    public void writeExcel(String filePath,String fileName,String sheetName,String[] dataToWrite) throws IOException{

        //Create an object of File class to open xlsx file

        File file =    new File(filePath+"\\"+fileName);

        //Create an object of FileInputStream class to read excel file

        FileInputStream inputStream = new FileInputStream(file);

        Workbook guru99Workbook = null;

        //Find the file extension by splitting  file name in substring and getting only extension name

        String fileExtensionName = fileName.substring(fileName.indexOf("."));

        //Check condition if the file is xlsx file

        if(fileExtensionName.equals(".xlsx")){

        //If it is xlsx file then create object of XSSFWorkbook class

        guru99Workbook = new XSSFWorkbook(inputStream);

        }

        //Check condition if the file is xls file

        else if(fileExtensionName.equals(".xls")){

            //If it is xls file then create object of XSSFWorkbook class

            guru99Workbook = new HSSFWorkbook(inputStream);

        }    

    //Read excel sheet by sheet name    

    Sheet sheet = guru99Workbook.getSheet(sheetName);

    //Get the current count of rows in excel file

    int rowCount = sheet.getLastRowNum()-sheet.getFirstRowNum();

    //Get the first row from the sheet

    Row row = sheet.getRow(0);

    //Create a new row and append it at last of sheet

    Row newRow = sheet.createRow(rowCount+1);

    //Create a loop over the cell of newly created Row

    for(int j = 0; j < row.getLastCellNum(); j++){

        //Fill data in row

        Cell cell = newRow.createCell(j);

        cell.setCellValue(dataToWrite[j]);

    }

    //Close input stream

    inputStream.close();

    //Create an object of FileOutputStream class to create write data in excel file

    FileOutputStream outputStream = new FileOutputStream(file);

    //write data in the excel file

    guru99Workbook.write(outputStream);

    //close output stream

    outputStream.close();
	
    }

    public static void main(String...strings) throws IOException{

        //Create an array with the data in the same order in which you expect to be filled in excel file

        String[] valueToWrite = {"Mr. E","Noida"};

        //Create an object of current class

        WriteGuru99ExcelFile objExcelFile = new WriteGuru99ExcelFile();

        //Write the file using file name, sheet name and the data to be filled

        objExcelFile.writeExcel(System.getProperty("user.dir")+"\\src\\excelExportAndFileIO","ExportExcel.xlsx","ExcelGuru99Demo",valueToWrite);

    }

}

Gravar dados em arquivo Excel

Manipulação do Excel usando API JXL

Manipulação do Excel usando API JXL

JXL também é outro jar famoso para ler arquivos Excel em Java e gravar arquivos. Hoje em dia, o POI é usado na maioria dos projetos, mas antes do POI, o JXL era apenas uma API Java para manipulação do Excel. É uma API muito pequena e simples para leitura de Excel em Selenium.

DICAS: Minha sugestão é não usar JXL em nenhum projeto novo porque a biblioteca não está em desenvolvimento ativo desde 2010 e falta do recurso em comparação com a API POI.

Baixe JXL:

Se quiser trabalhar com JXL, você pode baixá-lo neste link

https://sourceforge.net/projects/jexcelapi/files/jexcelapi/2.6.12/

Manipulação do Excel usando API JXL

Você também pode obter um exemplo de demonstração dentro deste arquivo compactado para JXL.

Alguns dos recursos:

  • JXL é capaz de ler arquivos Excel em Selenium para pasta de trabalho 95, 97, 2000, XP, 2003.
  • Podemos trabalhar com inglês, francês, espanhol, alemão.
  • É possível copiar um gráfico e inserir imagens no Excel

Recua:

  • Podemos escrever Excel 97 e later apenas (escrever no Excel 95 não é suportado).
  • JXL não suporta o formato XLSX de arquivo Excel.
  • Gera planilha no formato Excel 2000.

Resumo

  • O arquivo Excel pode ser lido pela operação Java IO. Para isso, precisamos usar Jarro POI Apache.
  • Existem dois tipos de pasta de trabalho no arquivo Excel, XLSX e XLS arquivos.
  • POI tem diferentes interfaces de pasta de trabalho, planilha, linha, célula.
  • Essas interfaces são implementadas por correspondentes XLS (HSSFWorkbook, HSSFSheet, HSSFrow, HSSFCell) e XLSX (XSSFWorkbook, XSSFSheet, XSSFrow, XSSFCell) classes de manipulação de arquivos.
  • JXL é outra API para manipulação de Excel em Selenium.
  • JXL não pode funcionar com o formato XLSX do Excel.