0

0

Java Selenium:验证网页表格数值列的排序功能

聖光之護

聖光之護

发布时间:2025-10-10 14:50:41

|

1019人浏览过

|

来源于php中文网

原创

java selenium:验证网页表格数值列的排序功能

本教程详细阐述了如何使用Java Selenium验证网页表格中数值列(如金额)的排序功能。内容涵盖从页面导航、登录、触发排序事件到提取、清洗表格数据,并最终通过数值比较断言其升序或降序排列的完整流程,确保自动化测试的准确性。在自动化测试中,验证网页表格数据的排序功能是常见的需求,尤其对于金融、电商等涉及大量数值数据的应用。本教程将以一个具体的示例,指导读者如何使用Java和Selenium WebDriver实现这一验证过程。

1. 环境准备

在开始之前,请确保您的开发环境已配置好以下组件:

  • Java Development Kit (JDK): 版本 8 或更高。
  • Maven 或 Gradle: 用于项目依赖管理。
  • Selenium WebDriver 库: 添加到您的项目依赖中。
  • JUnit 或 TestNG: Java 测试框架,用于编写和运行测试。
  • ChromeDriver: 与您的Chrome浏览器版本兼容的WebDriver可执行文件。

Maven 依赖示例:


    
        org.seleniumhq.selenium
        selenium-java
        4.1.2 
    
    
        org.junit.jupiter
        junit-jupiter-api
        5.8.1 
        test
    
    
        org.junit.jupiter
        junit-jupiter-engine
        5.8.1 
        test
    

2. 第一步:页面导航与用户登录

首先,我们需要初始化WebDriver,导航到目标网页的登录页面,并执行登录操作。

import org.junit.jupiter.api.*;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.ui.ExpectedConditions;
import org.openqa.selenium.support.ui.WebDriverWait;

import java.time.Duration;

public class TableSortVerificationTest {

    private static WebDriver driver;
    private static WebDriverWait wait;

    @BeforeAll
    public static void setup() {
        // 设置ChromeDriver路径,请根据您的实际路径修改
        System.setProperty("webdriver.chrome.driver", "path/to/your/chromedriver.exe");
        driver = new ChromeDriver();
        driver.manage().window().maximize(); // 最大化浏览器窗口
        wait = new WebDriverWait(driver, Duration.ofSeconds(10)); // 初始化显式等待
    }

    @BeforeEach
    public void login() {
        driver.get("https://sakshingp.github.io/assignment/login.html");

        // 等待用户名输入框可见并输入用户名
        wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("username"))).sendKeys("Lakshay");
        // 等待密码输入框可见并输入密码
        wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("password"))).sendKeys("Wingify");

        // 点击登录按钮
        wait.until(ExpectedConditions.elementToBeClickable(By.id("log-in"))).click();

        // 登录后等待页面跳转到home.html
        wait.until(ExpectedConditions.urlContains("home.html"));
    }

    // ... 后续测试方法 ...

    @AfterAll
    public static void tearDown() {
        if (driver != null) {
            driver.quit(); // 关闭浏览器
        }
    }
}

3. 第二步:触发表格列排序

登录成功后,页面会跳转到包含表格的页面。我们需要定位到“Amount”列的标题元素,并点击它以触发排序。通常,第一次点击会按升序排序,第二次点击则按降序排序。

立即学习Java免费学习笔记(深入)”;

知了追踪
知了追踪

AI智能信息助手,智能追踪你的兴趣资讯

下载
// ... 在 TableSortVerificationTest 类中添加 ...

import org.openqa.selenium.WebElement;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class TableSortVerificationTest {
    // ... setup, login, tearDown methods ...

    @Test
    @DisplayName("验证Amount列的升序排序")
    public void verifyAmountColumnAscendingSort() {
        // 1. 点击“Amount”列头,触发升序排序
        WebElement amountHeader = wait.until(ExpectedConditions.elementToBeClickable(By.id("amount")));
        amountHeader.click();

        // 添加一个短暂的等待,确保页面数据已经重新加载和排序
        // 更好的做法是等待特定元素状态变化,例如等待表格行的文本发生变化或加载指示器消失
        // 这里我们简单等待表格第一行第一个单元格的文本变得“陈旧”,表示页面内容已刷新
        wait.until(ExpectedConditions.stalenessOf(driver.findElement(By.xpath("//*[@id=\"transactionsTable\"]/tbody/tr[1]/td[1]"))));

        // 2. 提取并清洗表格数据
        List actualAmounts = extractAndCleanAmountData();

        // 3. 创建一个期望的排序列表
        List expectedSortedAmounts = new ArrayList<>(actualAmounts);
        Collections.sort(expectedSortedAmounts); // 默认升序排序

        // 4. 验证实际数据是否与期望的升序数据一致
        Assertions.assertEquals(expectedSortedAmounts, actualAmounts, "Amount列未按升序排列!");
        System.out.println("Amount列已成功验证为升序排列。");
    }

    @Test
    @DisplayName("验证Amount列的降序排序")
    public void verifyAmountColumnDescendingSort() {
        // 首先点击一次,确保进入升序状态
        WebElement amountHeader = wait.until(ExpectedConditions.elementToBeClickable(By.id("amount")));
        amountHeader.click();
        wait.until(ExpectedConditions.stalenessOf(driver.findElement(By.xpath("//*[@id=\"transactionsTable\"]/tbody/tr[1]/td[1]"))));

        // 再次点击“Amount”列头,触发降序排序
        amountHeader.click();
        wait.until(ExpectedConditions.stalenessOf(driver.findElement(By.xpath("//*[@id=\"transactionsTable\"]/tbody/tr[1]/td[1]"))));

        // 2. 提取并清洗表格数据
        List actualAmounts = extractAndCleanAmountData();

        // 3. 创建一个期望的排序列表
        List expectedSortedAmounts = new ArrayList<>(actualAmounts);
        Collections.sort(expectedSortedAmounts, Collections.reverseOrder()); // 降序排序

        // 4. 验证实际数据是否与期望的降序数据一致
        Assertions.assertEquals(expectedSortedAmounts, actualAmounts, "Amount列未按降序排列!");
        System.out.println("Amount列已成功验证为降序排列。");
    }

    /**
     * 辅助方法:提取并清洗“Amount”列的数据
     * @return 包含Double类型金额的列表
     */
    private List extractAndCleanAmountData() {
        // 定位所有“Amount”列的数据单元格(假设“Amount”是第5列,且数据在span标签内)
        List amountElements = driver.findElements(By.xpath("//*[@id=\"transactionsTable\"]/tbody/tr/td[5]/span"));
        List amounts = new ArrayList<>();

        for (WebElement element : amountElements) {
            String text = element.getText();
            // 清洗字符串:移除“USD”、逗号、空格,并解析为Double
            // 示例数据可能包含负号,如 "- 250.00 USD"
            String cleanedText = text.replaceAll("USD", "")
                                     .replaceAll(",", "")
                                     .trim(); // 移除首尾空格
            amounts.add(Double.parseDouble(cleanedText));
        }
        return amounts;
    }
}

4. 第三步:提取并清洗表格数据

这一步是核心,它决定了我们如何从网页中获取数据并为数值比较做好准备。

  1. 定位数据单元格: 使用XPath或CSS选择器定位到表格中“Amount”列的所有数据单元格。根据HTML结构,示例网站的金额数据位于 id="transactionsTable" 表格的 tbody 下的 tr 中的 td (第五列) 内部的 span 标签中。
  2. 提取文本: 遍历所有定位到的WebElement,使用getText()方法获取其文本内容。
  3. 清洗数据: 原始文本可能包含货币符号(如“USD”)、千位分隔符(逗号)以及额外的空格。为了进行准确的数值比较,必须将这些非数字字符移除。
  4. 类型转换: 将清洗后的字符串转换为 Double 或 BigDecimal 类型。直接对字符串进行排序会导致词典序排序,而非数值排序(例如,“100”在字符串排序中可能排在“20”之后,但在数值排序中则相反)。

上述代码中的 extractAndCleanAmountData() 辅助方法已经实现了这一逻辑。

5. 第四步:验证数据排序顺序

在提取和清洗数据之后,我们需要验证实际获取的数据是否按照预期的顺序排列。

  1. 创建实际数据列表: actualAmounts 列表存储从UI中提取并清洗后的数值。
  2. 创建期望数据列表: expectedSortedAmounts 列表是 `actualAmounts

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

832

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

738

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

734

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

20

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号