当前位置: 首页 > news >正文

使用 Java 来读取 Excel 文件,检查每一行中的 URL,并将不符合条件的行标记为红色

 -- 日、时、分、秒,这是计时的单位,惜时就应该惜日、惜时、惜分、惜秒。

用 Java 来读取 Excel 文件,检查每一行中的 URL,并将不符合条件的行标记为红色。以下是一个简单的示例,使用 Apache POI 进行 Excel 操作:

首先,你需要添加 Apache POI 的依赖。如果是 Maven 项目,可以在 pom.xml 文件中添加:

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.1.2</version> <!-- 使用适当的版本 -->
</dependency>
 

json 格式

{
    "yourArrayKey":[
    {
        
        "url":"http://epaper.jwb.com.cn/jwb"
        
    },
    {
        "url":"http://epaper.jwb.com.cn/jwb"
    }
]
}

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URL;public class ExcelValidator {public static void main(String[] args) {String excelFilePath = "path/to/your/excel/file.xlsx";try {markInvalidRows(excelFilePath);} catch (IOException e) {e.printStackTrace();}}private static void markInvalidRows(String excelFilePath) throws IOException {FileInputStream excelFile = new FileInputStream(new File(excelFilePath));Workbook workbook = new XSSFWorkbook(excelFile);Sheet sheet = workbook.getSheetAt(0);for (Row row : sheet) {Cell urlCell = row.getCell(0); // Assuming URL is in the first column (index 0)if (urlCell != null && urlCell.getCellType() == CellType.STRING) {String url = urlCell.getStringCellValue();boolean isValid = isValidUrl(url);if (!isValid) {markRowAsInvalid(row);}}}excelFile.close();// Save the changes back to the Excel fileFileOutputStream outputStream = new FileOutputStream(excelFilePath);workbook.write(outputStream);workbook.close();outputStream.close();}private static boolean isValidUrl(String urlString) {try {URL url = new URL(urlString);HttpURLConnection connection = (HttpURLConnection) url.openConnection();connection.setRequestMethod("HEAD");connection.connect();int responseCode = connection.getResponseCode();long responseTime = connection.getHeaderFieldDate("Date", 0) - connection.getHeaderFieldDate("Date", 0);return responseCode == HttpURLConnection.HTTP_OK && responseTime <= 20;} catch (Exception e) {return false;}}private static void markRowAsInvalid(Row row) {CellStyle style = row.getSheet().getWorkbook().createCellStyle();style.setFillForegroundColor(IndexedColors.RED.getIndex());style.setFillPattern(FillPatternType.SOLID_FOREGROUND);for (Cell cell : row) {cell.setCellStyle(style);}}
}

相关文章:

使用 Java 来读取 Excel 文件,检查每一行中的 URL,并将不符合条件的行标记为红色

-- 日、时、分、秒&#xff0c;这是计时的单位&#xff0c;惜时就应该惜日、惜时、惜分、惜秒。 用 Java 来读取 Excel 文件&#xff0c;检查每一行中的 URL&#xff0c;并将不符合条件的行标记为红色。以下是一个简单的示例&#xff0c;使用 Apache POI 进行 Excel 操作&#…...

雷达公式实现(matlab)

雷达公式实现 代码来源&#xff1a;《雷达系统分析与设计(MATLAB版)(第三版)》 function [snr] radar_eq(pt,freq,g,sigma,b,nf,loss,range) % This program implements Eq.(1.63) %% Inputs:% pt——峰值功率&#xff0c;W% freq——雷达中心频率&#xff0c;Hz% g——天线…...

CMake构建一个转换为3d tile的开源代码成功

之前CMake构建一个转换为3d tile的开源代码&#xff0c;生成解决方案之后&#xff0c;从VS2019打开&#xff1b; 总是报一个错误&#xff0c;跟 mocs_compilation_Debug.cpp 这个QT相关文件有关&#xff0c;它生成的obj&#xff0c;总是报模块计算机x64和目标计算机x86冲突&am…...

Java线程通信

线程通信 案例 package com.itheima.d4;public class ThreadTest {public static void main(String[] args) {Desk desk new Desk();//创建3个生产者线程new Thread(() -> {while (true) {desk.put();}}, "厨师1").start();new Thread(() -> {while (true) {…...

计算4人队形的最可能分布

2 2 2 1 2 2 2 2 2 1 2 2 2 2 2 1 2 2 3 3 3 x 3 3 2 2 2 1 2 2 2 2 2 1 2 2 在6*6的平面上2个点随机分布&#xff0c;有3种分布方式&#xff0c;2a1&#xff0c;2a2&#xff0c;2a3&#xff0c;占比为1&#xff1a;5&#xff1a;1. 3 3 …...

如何解决 Java 中的 IllegalArgumentException 异常?

非法参数异常&#xff08;IllegalArgumentException&#xff09;的抛出是为了表明一个方法被传递了一个非法参数。该异常扩展了 RuntimeException 类&#xff0c;因此属于在 Java 虚拟机&#xff08;JVM&#xff09;运行期间可能抛出的异常。它是一种未检查异常&#xff0c;因此…...

Vue 双向数据绑定

之前通过v-bind来完成的数据绑定&#xff0c;属性值和表达式进行绑定&#xff0c;表达式的值发生变化了属性值也跟着发生变化。 单向数据绑定&#xff1a; <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title>首页</titl…...

电脑开机过程中,程序的启动的顺序是怎么样的?

电脑的启动过程涉及多个步骤,程序按照特定的顺序启动。这个过程通常如下: 电源开启: 当你按下电源按钮时,电源供应器(PSU)开始向电脑的各个组件供电。 自检加电(POST): 这是电脑启动过程的第一步。在这个阶段,基本输入输出系统(BIOS)或统一可扩展固件接口(UEFI)执行…...

JSON详细教程

&#x1f60a;JSON详细教程 &#x1f6a9;JSON简介☃️JSON语法规则&#x1f50a;JSON和JavaScript对象的区别 ☃️JSON数据类型字符串&#x1f50a;数字&#x1f50a;布尔值&#x1f50a;数组&#x1f50a;对象&#x1f50a;Null ☃️JSON对象&#x1f50a;访问JSON对象的值&a…...

DSP介绍及CCS

文章目录 CCS版本编译器CCS使用注意严禁中文 CCS的基本操作新建工程导入现有工程调整字体的大小工程界面恢复标签的使用 仿真盒小虫子进入在线Debug 仿真器芯片TMS320F28355基本介绍特性 DSP中特殊指令dsp指令中的EALLOW EDIS CCS TI官网 版本 CCS版本&#xff1a; CCS8.3.1…...

周期串(Periodic Strings)

做了我两个小时&#xff0c;我真的裂开 之前已经发过一次了&#xff0c;走在回宿舍的路上突然发现有些情况并不适用&#xff0c;赶紧删掉了 题目如下&#xff1a; 如果一个字符串可以由某个长度为k的字符串重复多次得到&#xff0c;则称该串以k为周期。例如&#xff1a;abca…...

C语言——猜凶手

题目&#xff1a; 日本某地发生了一件谋杀案&#xff0c;警察通过排查确定杀人凶手必为4个嫌疑犯的一个。 以下为4个嫌疑犯的供词: A说&#xff1a;不是我。 B说&#xff1a;是C。 C说&#xff1a;是D。 D说&#xff1a;C在胡说 已知3个人说了真话&#xff0c;1个人说的是假话。…...

【TiDB】TiDB离线方式部署

目录 1 下载TiDB离线组件包 2 安装TiUP 3 合并离线包 4 TIDB 软件和硬件环境建议配置 5 TiDB环境与系统配置检查 6 生成集群初始化配置文件模板 7 执行部署命令 1 检查就能存在的潜在风险 2 手动修复风险 3 部署 TiDB 集群 8 查看TIUP管理的集群情况 9 检查部署的…...

android shape绘制半圆

<?xml version"1.0" encoding"utf-8"?><shape xmlns:android"http://schemas.android.com/apk/res/android"android:shape"rectangle"><sizeandroid:width"20dp"android:height"10dp" /><…...

【开源】基于Vue和SpringBoot的个人健康管理系统

项目编号&#xff1a; S 040 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S040&#xff0c;文末获取源码。} 项目编号&#xff1a;S040&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 健康档案模块2.2 体检档案模块2.3 健…...

qt QString字符串常用转换

QString字符串转换类型,常见的有: 1. const char*初始化QString.即const char*类型转QString字符串类型. QString str("肖战");qDebug() <<str; 2. QChar数组初始化QString.即QChar字符数组转QString字符串. QChar cHello[5] {H,e,l,l,o};QString strHell…...

JAVA sql 查询3

-- 1. 求各个月入职的的员工个数 select date_format(hiredate,%m),count(date_format(hiredate,%m)) from employees group by date_format(hiredate,%m) -- 2. 查询 50 号部门,60 号部门,70 号部门的各个部门的平均工资 SELECT department_id,avg(salary) FROM employees WH…...

PHP while 和 do-while 循环 学习资料

PHP while 和 do-while 循环 在 PHP 中&#xff0c;while 和 do-while 是两种常用的循环结构&#xff0c;用于重复执行一段代码&#xff0c;直到满足指定条件为止。以下是对这两种循环的介绍和示例&#xff1a; while 循环 while 循环用于在指定条件为真时重复执行代码块。循…...

OpenJudge NOI 1.8 16:矩阵剪刀石头布 c语言

描述 Bart的妹妹Lisa在一个二维矩阵上创造了新的文明。矩阵上每个位置被三种生命形式之一占据&#xff1a;石头&#xff0c;剪刀&#xff0c;布。每天&#xff0c;上下左右相邻的不同生命形式将会发生战斗。在战斗中&#xff0c;石头永远胜剪刀&#xff0c;剪刀永远胜布&#…...

mysql 性能参数调优详解

1 优化连接池 连接池运行机制 MySQL连接器中的连接池&#xff0c;用以提高数据库密集型应用程序的性能和可扩展性&#xff0c;默认启用。MySQL连接器负责管理连接池中的多个连接&#xff0c;自动创建、打开、关闭和破坏连接&#xff0c;多个连接的创建&#xff0c;可满足多客户…...

别再为reg2icg的setup违例头疼了!手把手教你用ICC2/Innovus这3招搞定(附实战数据对比)

3大实战技巧彻底解决ICC2/Innovus中reg2icg的setup违例问题 在数字芯片后端设计中&#xff0c;时钟门控单元(ICG)与寄存器之间的时序路径(reg2icg)一直是工程师们最头疼的问题之一。特别是在先进工艺节点下&#xff0c;这类路径经常出现setup违例&#xff0c;直接影响芯片性能甚…...

华三SR-MPLS TE静态配置避坑指南:从OSPF 10类LSA抓包到隧道接口配置的完整排错流程

华三SR-MPLS TE静态配置实战排错手册&#xff1a;从LSA解析到隧道建立的深度诊断 当你在HCL模拟器中完成华三设备SR-MPLS TE的基础配置后&#xff0c;发现隧道状态始终显示为Down&#xff0c;或者流量没有按照预定路径转发——这种场景下&#xff0c;传统的配置检查清单往往难以…...

蓝牙耳机天线匹配调试实战:从仪器校准到阻抗调整的完整流程

蓝牙耳机天线匹配调试实战&#xff1a;从仪器校准到阻抗调整的完整流程 在无线音频设备领域&#xff0c;蓝牙耳机的射频性能直接决定了用户体验。天线作为信号收发的门户&#xff0c;其匹配调试是产品开发中最关键的环节之一。本文将深入剖析从仪器准备到参数优化的全流程操作要…...

零代码革命!Spring AI + Ollama 实现本地模型 MCP 全自动调用(含实战代码)

1. 为什么你需要关注Spring AI Ollama的MCP全自动调用 最近两年AI技术发展迅猛&#xff0c;但很多开发者面临一个尴尬局面&#xff1a;想要在自己的应用中集成AI能力&#xff0c;要么得忍受云服务API的高延迟和高成本&#xff0c;要么就得面对本地模型部署的复杂技术栈。我去年…...

2026届最火的五大AI论文工具横评

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 借助人工智能来辅助撰写开题报告&#xff0c;可显著提高研究框架构建的效率&#xff0c;在用…...

看Anything V5如何玩转AI绘画:从简单描述到复杂场景的生成效果案例

看Anything V5如何玩转AI绘画&#xff1a;从简单描述到复杂场景的生成效果案例 如果你对AI绘画感兴趣&#xff0c;一定听说过Stable Diffusion。而Anything V5&#xff0c;就是基于这个强大框架的一个特别版本&#xff0c;它在动漫、二次元风格的图像生成上表现尤为出色。今天…...

基于Matlab和Cplex的微电网优化调度研究:涵盖风光热储能及多场景负荷模拟分析

考虑风光火储的微电网优化调度 软件&#xff1a;Matlabcplex 介绍&#xff1a;考虑风电、光伏、热电机组和储能优化调度&#xff0c;其中负荷考虑冬季或夏季两种场景&#xff0c;并且考虑晴天、多云、雨天、多风和少风场景&#xff0c;对风机考虑相应的故障概率&#xff0c;以火…...

腾讯优图轻量模型惊艳表现:4B参数媲美大模型的效果实测

腾讯优图轻量模型惊艳表现&#xff1a;4B参数媲美大模型的效果实测 1. 引言&#xff1a;小身材大能量的视觉语言模型 在AI领域&#xff0c;模型参数量的军备竞赛似乎从未停歇。当大多数研究机构都在追求千亿甚至万亿参数规模时&#xff0c;腾讯优图实验室却反其道而行之&…...

MoE架构演进全景图,从Mixtral到2026奇点大会最新动态及企业部署路线图

第一章&#xff1a;MoE架构演进全景图&#xff1a;从Mixtral到2026奇点大会的范式跃迁 2026奇点智能技术大会(https://ml-summit.org) MoE&#xff08;Mixture of Experts&#xff09;已从早期稀疏路由实验&#xff0c;演进为支撑万亿参数模型落地的核心范式。Mixtral 8x7B 的…...

滚动轴承故障诊断的MATLAB分析方法:基于快速谱峭度与包络谱结合的研究方法

滚动轴承故障诊断MATLAB程序&#xff1a;快速谱峭度、谱峭度包络谱分析 滚动轴承故障诊断是机械工程领域的一个重要研究方向。滚动轴承是一种常见的机械元件&#xff0c;用于支撑和转动机械装置中的轴。然而&#xff0c;由于长时间使用或其他原因&#xff0c;滚动轴承可能会出现…...