多线程解析报表

2024-09-09 06:38
文章标签 多线程 解析 报表

本文主要是介绍多线程解析报表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。


Way1
join
import java.time.LocalTime;public class Main {public static void main(String[] args) throws InterruptedException {Thread sheet1 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet1 begin");try {Thread.sleep(5000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet1 finish");}});Thread sheet2 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet2 begin");try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet2 finish");}});System.out.println(LocalTime.now() + " all parser begin");sheet1.start();sheet2.start();sheet1.join();sheet2.join();System.out.print(LocalTime.now() + " all parser finish");}}


Way2
CountDownLatch
import java.time.LocalTime;
import java.util.concurrent.CountDownLatch;public class Main {public static void main(String[] args) throws InterruptedException {CountDownLatch latch =  new CountDownLatch(2);Thread sheet1 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet1 begin");try {Thread.sleep(5000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet1 finish");latch.countDown(); ;}});Thread sheet2 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet2 begin");try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet2 finish");latch.countDown(); ;}});System.out.println(LocalTime.now() + " all parser begin");sheet1.start();sheet2.start();latch.await();System.out.print(LocalTime.now() + " all parser finish");}}

python

import time
import threadingdef sheet1():print(time.strftime("%H:%M:%S")+ " sheet1 begin")time.sleep(5)print(time.strftime("%H:%M:%S") + " sheet1 end")def sheet2():print(time.strftime("%H:%M:%S")+ " sheet2 begin")time.sleep(10)print(time.strftime("%H:%M:%S") + " sheet2 end")if __name__ == '__main__':print(time.strftime("%H:%M:%S") + " all parser begin")thread1 = threading.Thread(target=sheet1)thread2 = threading.Thread(target=sheet2)thread1.start()thread2.start()thread1.join()thread2.join()print(time.strftime("%H:%M:%S") + " all parser end")


这篇关于多线程解析报表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1150436

相关文章

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

Java解析JSON的六种方案

《Java解析JSON的六种方案》这篇文章介绍了6种JSON解析方案,包括Jackson、Gson、FastJSON、JsonPath、、手动解析,分别阐述了它们的功能特点、代码示例、高级功能、优缺点... 目录前言1. 使用 Jackson:业界标配功能特点代码示例高级功能优缺点2. 使用 Gson:轻量

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象