0

0

使用 Java + Selenium 读取 CSV 两列数据并逐行填充表单元素

花韻仙語

花韻仙語

发布时间:2026-02-02 12:47:03

|

434人浏览过

|

来源于php中文网

原创

使用 Java + Selenium 读取 CSV 两列数据并逐行填充表单元素

本文介绍如何用 java 和 selenium 自动化处理 csv 文件中的两列数据,将每行第一列填入页面第一个输入框、第二列填入第二个输入框,并执行后续点击操作,实现高效批量表单提交

在 Web 自动化测试或数据录入场景中,常需将结构化数据(如 CSV)映射到网页表单字段。当 CSV 包含两列(例如:用户名、邮箱),且页面对应两个 元素时,关键在于按行索引精准访问数组元素,而非嵌套遍历所有字段。

以下为完整、健壮的实现方案:

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import java.io.File;
import java.io.FileNotFoundException;
import java.util.ArrayList;
import java.util.Scanner;

// 假设 driver 已初始化(如 ChromeDriver)
WebDriver driver = ...; 

try (Scanner scan = new Scanner(new File("data.csv"))) {
    ArrayList records = new ArrayList<>();

    // 逐行读取 CSV,按逗号分割(注意:简单场景可用;含逗号/引号需用 OpenCSV 等库)
    while (scan.hasNextLine()) {
        String line = scan.nextLine().trim();
        if (!line.isEmpty()) {
            String[] record = line.split(",", -1); // -1 保留空字段
            if (record.length >= 2) {
                records.add(record);
            }
        }
    }

    // 核心逻辑:逐行处理,record[0] → Element1,record[1] → Element2
    for (String[] record : records) {
        try {
            // 显式等待确保元素可交互(推荐替代直接 findElement)
            WebElement input1 = driver.findElement(By.id("Element1"));
            WebElement input2 = driver.findElement(By.id("Element2"));

            input1.clear(); // 避免残留内容
            input1.sendKeys(record[0].trim());

            input2.clear();
            input2.sendKeys(record[1].trim());

            driver.findElement(By.id("Element3")).click();
            driver.findElement(By.id("Element4")).click();

            // 可选:添加短暂停顿或页面校验(如成功提示出现)
            Thread.sleep(1000); // 生产环境建议用 WebDriverWait 替代

        } catch (Exception e) {
            System.err.println("处理行失败 [" + String.join(",", record) + "]: " + e.getMessage());
            // 可记录日志、截图或跳过当前行继续执行
        }
    }

} catch (FileNotFoundException e) {
    throw new RuntimeException("CSV 文件未找到: data.csv", e);
}

关键要点说明:

智川X-Agent
智川X-Agent

中科闻歌推出的一站式AI智能体开发平台

下载
  • 取消内层循环:原代码中 for (String temp1 : temp) 会将同一行的两个值都塞进 Element1,导致逻辑错误;正确做法是直接通过下标 record[0] 和 record[1] 分别赋值。
  • 增强健壮性:添加 trim() 去除首尾空格、isEmpty() 和 length >= 2 校验、异常捕获与错误提示,避免单行失败中断整个流程。
  • 生产级建议
    • 使用 Apache Commons CSVOpenCSV 解析复杂 CSV(支持引号包裹、换行符等);
    • 用 WebDriverWait 替代 Thread.sleep() 实现智能等待;
    • 将定位器(By.id)提取为常量或 Page Object 模式,提升可维护性;
    • 对敏感操作(如 click)添加 isDisplayed() 和 isEnabled() 判断。

通过此方案,你即可稳定、清晰地完成“一CSV行→两表单字段→多操作”的自动化闭环,大幅提升重复性任务执行效率。

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

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

523

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1505

2023.10.24

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

929

2023.09.19

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

87

2025.12.01

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

187

2023.11.24

apache是什么意思
apache是什么意思

Apache是Apache HTTP Server的简称,是一个开源的Web服务器软件。是目前全球使用最广泛的Web服务器软件之一,由Apache软件基金会开发和维护,Apache具有稳定、安全和高性能的特点,得益于其成熟的开发和广泛的应用实践,被广泛用于托管网站、搭建Web应用程序、构建Web服务和代理等场景。本专题为大家提供了Apache相关的各种文章、以及下载和课程,希望对各位有所帮助。

411

2023.08.23

apache启动失败
apache启动失败

Apache启动失败可能有多种原因。需要检查日志文件、检查配置文件等等。想了解更多apache启动的相关内容,可以阅读本专题下面的文章。

931

2024.01.16

PHP 命令行脚本与自动化任务开发
PHP 命令行脚本与自动化任务开发

本专题系统讲解 PHP 在命令行环境(CLI)下的开发与应用,内容涵盖 PHP CLI 基础、参数解析、文件与目录操作、日志输出、异常处理,以及与 Linux 定时任务(Cron)的结合使用。通过实战示例,帮助开发者掌握使用 PHP 构建 自动化脚本、批处理工具与后台任务程序 的能力。

44

2025.12.13

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

11

2026.02.02

热门下载

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

精品课程

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

共23课时 | 3.1万人学习

C# 教程
C# 教程

共94课时 | 8.3万人学习

Java 教程
Java 教程

共578课时 | 55.6万人学习

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

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