《手把手教你》系列技巧篇(六十八)-java+ selenium自动化测试 - 读写excel文件 - 下篇(详细教程)

简介: 【6月更文挑战第9天】本文介绍了如何使用Java处理Excel文件中的不同数据类型,包括日期、数字、布尔值和标签(常规字符串)。文章提供了两个示例,分别使用JXL库和Apache POI库来读取Excel文件。

1.简介

今天继续操作Excle,小伙伴或者童鞋们是不是觉得宏哥会介绍第三种工具操作Excle,今天不介绍了,有两种就够用了,其实一种就够用了,今天主要是来介绍如何使用不同的数据类型读取Excel文件。在实际测试中,您可能不得不处理除String之外的多个数据类型的Excel文件数据。 在本教程中,我们将使用不同的数据类型读取Java中的excel文件。

2.准备不同数据类型的Excle

1.我们将尝试读取下面的excel,因为可以看出,excel在前四个单元中有Date,Number,Boolean和Label(常规字符串)数据。

2.把这个文件放到eclipse项目中,如下图所示:

3.JXL使用不同的数据类型读取Excel文件

3.1代码设计

1.新建一个OperateExcle.java的文件,输入如下代码。

3.2参考代码

package lessons;


import java.io.File;

import java.io.IOException;


import jxl.BooleanCell;

import jxl.Cell;

import jxl.CellType;

import jxl.DateCell;

import jxl.LabelCell;

import jxl.NumberCell;

import jxl.Sheet;

import jxl.Workbook;

import jxl.read.biff.BiffException;


/**

* @author 北京-宏哥

*

* @公众号:北京宏哥

*

* 《手把手教你》系列技巧篇(六十八)-java+ selenium自动化测试 - 读写excel文件 -下篇(详细教程)

*

* 2022年2月15日

*/


public class OperateExcle {

   

   public static void main(String[] args) {    

       //从指定位置的文件创建工作簿对象;根据计算机上的位置更改文件的路径。

       Workbook wrk1;

       try {

       

           wrk1 = Workbook.getWorkbook(new File(".\\Files\\test-data1.xls"));


           //获取工作簿中第一个工作表的引用

           Sheet sheet1 = wrk1.getSheet(0);


          //使用工作表的getCel(int col, int row)方法获取对单元的引用

           Cell cell1 = sheet1.getCell(0, 0);

           Cell cell2 = sheet1.getCell(1, 0);

           Cell cell3 = sheet1.getCell(2, 0);

           Cell cell4 = sheet1.getCell(3, 0);


           DateCell dCell = null;

           NumberCell nCell = null;

           BooleanCell bCell = null;

           LabelCell lCell = null;


           // 检查单元格内容的类型,并将该对象转换为适当的引用类型

           if (cell1.getType() == CellType.DATE)

               dCell = (DateCell) cell1;


           if (cell2.getType() == CellType.NUMBER)

               nCell = (NumberCell) cell2;


           if (cell3.getType() == CellType.BOOLEAN)

               bCell = (BooleanCell) cell3;


           if (cell4.getType() == CellType.LABEL)

               lCell = (LabelCell) cell4;


           // 显示单元格内容

           System.out.println("Value of Date Cell is: " + dCell.getDate());

           System.out.println("Value of Number Cell is: " + nCell.getValue());

           System.out.println("Value of Boolean Cell is: " + bCell.getValue());

           System.out.println("Value of Label Cell is: " + lCell.getString());


       } catch (BiffException e) {

           e.printStackTrace();

       } catch (IOException e) {

           e.printStackTrace();

       }


   }



}

3.3运行代码

1.运行代码,右键Run AS->Java Appliance,控制台输出,如下图所示:

4.POI使用不同的数据类型读取Excel文件

4.1代码设计

1.新建一个ReadDiffExcel.java的文件,输入如下代码。

4.2参考代码

package lessons;


import java.io.File;

import java.io.FileInputStream;

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

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

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

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


/**

* @author 北京-宏哥

*

* @公众号:北京宏哥

*

* 《手把手教你》系列技巧篇(六十八)-java+ selenium自动化测试 - 读写excel文件 -下篇(详细教程)

*

* 2022年2月15日

*/

public class ReadDiffExcle {


   public static void main(String[] args) {

       File f = new File(".\\Files\\test-data1.xls");

       try {

               FileInputStream is = new FileInputStream(f);

               @SuppressWarnings("resource")

               HSSFWorkbook wbs = new HSSFWorkbook(is);

               HSSFSheet childSheet = wbs.getSheetAt(0);

               // System.out.println(childSheet.getPhysicalNumberOfRows());

               System.out.println("有行数" + childSheet.getLastRowNum());

               for (int j = 0; j < childSheet.getLastRowNum(); j++) {

                       HSSFRow row = childSheet.getRow(j);

                       // System.out.println(row.getPhysicalNumberOfCells());

                       // System.out.println("有列数" + row.getLastCellNum());

                       if (null != row) {

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

                                       HSSFCell cell = row.getCell(k);

                                       if (null != cell) {

                                               switch (cell.getCellType()) {

                                               case NUMERIC: // 数字

                                                       System.out.print(cell.getNumericCellValue()

                                                                       + "   ");

                                                       break;

                                               case STRING: // 字符串

                                                       System.out.print(cell.getStringCellValue()

                                                                       + "   ");

                                                       break;

                                               case BOOLEAN: // Boolean

                                                       System.out.print(cell.getBooleanCellValue()

                                                                       + "   ");

                                                       break;

                                               case FORMULA: // 公式

                                                       System.out.print(cell.getCellFormula() + "   ");

                                                       break;

                                               case BLANK: // 空值

                                                       System.out.print(" ");

                                                       break;

                                               case ERROR: // 故障

                                                       System.out.print(" ");

                                                       break;

                                               default:

                                                       System.out.print("未知类型   ");

                                                       break;

                                               }

                                       } else {

                                               System.out.print("-   ");

                                       }

                               }

                       }

                       System.out.println();

               }

       } catch (Exception e) {

               e.printStackTrace();

       }

}


}

4.3运行代码

1.运行代码,右键Run AS->Java Appliance,控制台输出,如下图所示:

5.小结

宏哥在代码运行的时候由于POIjar包的升级,有些变量可能会和旧的版本有区别,运行过程报错:java.lang.ClassNotFoundException: org.apache.commons.math3.util.ArithmeticUtils。可能是由于引入小数,需要数学的jar包,将其引入项目中成功解决报错。


每天学习一点,今后必成大神-


往期推荐(由于跳转参数丢失了,所有建议选中要访问的右键,在新标签页中打开链接即可访问):


Appium自动化系列,耗时80天打造的从搭建环境到实际应用精品教程测试

Python接口自动化测试教程,熬夜87天整理出这一份上万字的超全学习指南

Python+Selenium自动化系列,通宵700天从无到有搭建一个自动化测试框架

Java+Selenium自动化系列,仿照Python趁热打铁呕心沥血317天搭建价值好几K的自动化测试框架

Jmeter工具从基础->进阶->高级,费时2年多整理出这一份全网超详细的入门到精通教程

Fiddler工具从基础->进阶->高级,费时100多天吐血整理出这一份全网超详细的入门到精通教程

Pycharm工具基础使用教程

 

相关文章
|
3天前
|
Java 测试技术 Python
《手把手教你》系列基础篇(七十九)-java+ selenium自动化测试-框架设计基础-TestNG依赖测试-下篇(详解教程)
【6月更文挑战第20天】TestNG是一个Java测试框架,提供两种测试方法依赖机制:强依赖(所有前置方法成功后才运行)和弱依赖(即使前置方法失败,后置方法仍运行)。文中通过代码示例展示了这两种依赖如何实现,并解释了当依赖方法失败时,如何影响后续方法的执行。文章还包含了TestNG Suite的运行结果截图来辅助说明。
22 8
|
2天前
|
Java 测试技术 Python
《手把手教你》系列基础篇(八十)-java+ selenium自动化测试-框架设计基础-TestNG依赖测试-番外篇(详解教程)
【6月更文挑战第21天】本文介绍了TestNG中测试方法的依赖执行顺序。作者通过一个实际的自动化测试场景展示了如何设计测试用例:依次打开百度、搜索“selenium”、再搜索“selenium+java”。代码示例中,`@Test`注解的`dependsOnMethods`属性用于指定方法间的依赖,确保执行顺序。如果不设置依赖,TestNG会按方法名首字母排序执行。通过运行代码,验证了依赖关系的正确性。
19 4
|
1天前
|
XML 存储 自然语言处理
基于Java+HttpClient+TestNG的接口自动化测试框架(四)-------参数存取处理
基于Java+HttpClient+TestNG的接口自动化测试框架(四)-------参数存取处理
|
19天前
|
存储 安全 测试技术
《手把手教你》系列技巧篇(六十三)-java+ selenium自动化测试 - cookie -上篇(详细教程)
【6月更文挑战第4天】本文介绍了Cookie和Session的概念及其用途。Cookie是服务器发送到浏览器并存储在本地的小型文本文件,用于记录用户信息,如登录状态。它分为会话Cookie(关闭浏览器即消失)和永久Cookie(设置过期时间)。Session则是在服务器端保存用户状态的一种方式,比Cookie更安全,但会占用服务器资源。Selenium提供了操作Cookie的API,包括添加、删除和获取Cookie。文章还提到了Cookie的优缺点,如大小限制和潜在的安全风险。
21 1
《手把手教你》系列技巧篇(六十三)-java+ selenium自动化测试 - cookie -上篇(详细教程)
|
5天前
|
Java 测试技术 Python
《手把手教你》系列基础篇(七十七)-java+ selenium自动化测试-框架设计基础-TestNG依赖测试- 上篇(详解教程)
【6月更文挑战第18天】TestNG是一个Java测试框架,它允许在测试方法间定义执行顺序和依赖关系。当不指定依赖时,TestNG默认按方法名首字母排序执行。`@Test`注解的`dependsOnMethods`属性用于指定方法依赖,如`test1`依赖`test4`,则实际执行顺序为`test4`、`test2`、`test3`、`test1`。如果依赖的方法失败,后续依赖的方法将被跳过。此外,`dependsOnGroups`属性通过组名指定依赖,方便管理多个相关测试方法。通过`groups`定义方法所属组,然后在其他方法中用`dependsOnGroups`引用这些组。
21 5
|
4天前
|
数据可视化 前端开发 Java
自动化测试框架的选择与实践: Selenium vs. TestComplete
【6月更文挑战第18天】在软件开发的海洋中,自动化测试是一艘能够确保产品质量和效率的坚固船只。本文将深入探讨两种流行的自动化测试框架——Selenium和TestComplete,从它们的优势、局限性到适用场景进行对比分析。我们将通过实际案例来揭示如何根据项目需求选择最合适的测试工具,并提供一些实用的实施建议。文章旨在为读者提供清晰的指导,帮助他们在自动化测试的旅程中做出明智的决定。
9 3
|
4天前
|
XML Web App开发 测试技术
《手把手教你》系列基础篇(七十八)-java+ selenium自动化测试-框架设计基础-TestNG依赖测试- 中篇(详解教程)
【6月更文挑战第19天】本文介绍了使用TestNG框架配置XML文件来管理测试用例的分组和依赖关系。
16 2
|
9天前
|
Web App开发 XML 安全
《手把手教你》系列基础篇(七十三)-java+ selenium自动化测试-框架设计基础-TestNG实现启动不同浏览器(详解教程)
【6月更文挑战第14天】本文介绍了如何使用TestNg进行自动化测试,特别是通过变量参数启动不同浏览器的步骤。
20 5
|
7天前
|
XML 测试技术 数据格式
《手把手教你》系列基础篇(七十五)-java+ selenium自动化测试-框架设计基础-TestNG实现DDT - 中篇(详解教程)
【6月更文挑战第16天】本文介绍了TestNG中`@DataProvider`的两种使用方法。本文通过实例展示了TestNG如何利用`@DataProvider`结合方法名和`ITestContext`来灵活地为测试方法传递参数。
12 1
|
10天前
|
监控 Java 测试技术
《手把手教你》系列基础篇(七十二)-java+ selenium自动化测试-框架设计基础-TestNG简单介绍(详解教程)
【6月更文挑战第13天】本文介绍了TestNG单元测试框架,它是一个灵感来源于JUnit和NUnit的测试框架,支持多种级别的测试,如单元测试、集成测试等。TestNG的特点包括丰富的注解、数据驱动测试、变量支持、自动生成HTML测试报告等。与JUnit和NUnit相比,TestNG在某些功能上更为强大。文章还详细讲解了如何在Eclipse中安装TestNG插件,提供了在线安装、更新站点安装和离线安装三种方法,并展示了安装成功的验证步骤。最后,通过一个项目实战案例展示了如何使用TestNG编写和运行测试代码。
16 2