使用ClosedXml查询Excel文件数据,匹配时间并显示
使用Nuget包管理器安装ClosedXml包,VS没网在https://www.nuget.org/ 下载后,包源本地安装至项目
函数:
private void SelectGrab(CancellationToken token, object state)
{
Data someItem;
while (!datas.IsEmpty)
{
datas.TryTake(out someItem);//清空原先的结果
}
if (File.Exists(filepath))
{
try
{
using (XLWorkbook wb = new XLWorkbook(filepath))
{
System.Threading.Tasks.Parallel.ForEach(wb.Worksheets,item=> //使用并行循环,提高效率
{
var rows = item.RowsUsed().Skip(1);//跳过标题行
System.Threading.Tasks.Parallel.ForEach(rows,ite=>
{
if (ite.Cell(2).GetString()!="")
{
DateTime nowTime = DateTime.FromOADate(double.Parse(ite.Cell(2).GetString()));//第二列为时间戳
if (state.ToString() == "0")//采取的筛选策略
{
if (nowTime >= StartTime && nowTime <= EndTime)
{
Data data = new Data(ite.Cell(1).GetString(), DateTime.FromOADate(double.Parse(ite.Cell(2).GetString())).ToString("yyyy/MM/dd"), ite.Cell(3).GetString(), ite.Cell(4).GetString(), ite.Cell(5).GetString(), ite.Cell(6).GetString(), ite.Cell(7).GetString());//自定义结构:包含excel表格中的列名项
datas.Add(data);//自定义集合保存结果
}
}
else//采取的筛选策略
{
System.Threading.Tasks.Parallel.ForEach(dateTimes, it =>//dateTimes为一个list,自定义添加
{
if (it == nowTime)
{
Data data = new Data(ite.Cell(1).GetString(), DateTime.FromOADate(double.Parse(ite.Cell(2).GetString())).ToString("yyyy/MM/dd"), ite.Cell(3).GetString(), ite.Cell(4).GetString(), ite.Cell(5).GetString(), ite.Cell(6).GetString(), ite.Cell(7).GetString());//自定义结构:包含excel表格中的列名项
datas.Add(data);
}
});
}
}
});
});
wb.Dispose();
}
setDT();//刷UI,也可以通过POST发送至UI
GC.Collect();
}
catch (Exception ex)
{
MessageBox.Show("不存在表单"+ StartTime.Year.ToString()+ex.Message);
setDT();//刷UI,也可以通过POST发送至UI
}
}
else
{
MessageBox.Show("源文件路径不存在");
setDT();//刷UI,也可以通过POST发送至UI
}
}
使用ClosedXml查询Excel文件数据,匹配时间并显示的更多相关文章
- 项目一:第四天 1、快递员的条件分页查询-noSession,条件查询 2、快递员删除(逻辑删除) 3、基于Apache POI实现批量导入区域数据 a)Jquery OCUpload上传文件插件使用 b)Apache POI读取excel文件数据
1. 快递员的条件分页查询-noSession,条件查询 2. 快递员删除(逻辑删除) 3. 基于Apache POI实现批量导入区域数据 a) Jquery OCUpload上传文件插件使用 b) ...
- Excel文件数据保存到SQL中
1.获取DataTable /// <summary> /// 查询Excel文件中的数据 /// </summary> /// <param name="st ...
- 上传读取Excel文件数据
/// <summary> /// 上传读取Excel文件数据 /// 来自http://www.cnblogs.com/cielwater /// </summary> // ...
- VC6.0读取Excel文件数据
啰嗦一下:本人所在公司从事碟式斯特林太阳能发电设备的研发与销售.单台设备图如下: 工作原理如下:整个设备大致可分为五个部分, 1.服务器,负责气象.发电等数据存取,电.网连接等处理: 2.气象站,通过 ...
- springMVC(5)---导入excel文件数据到数据库
springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...
- selenium实现excel文件数据的读、写
在进行软件测试或设计自动化测试框架时,一个不可避免的过程就是: 参数 化,在利用 python 进行自动化测试开发时,通常会使用 excel 来做数据管 理,利用 xlrd.xlwt 开源包来读写 e ...
- ci框架读取上传的excel文件数据
原文链接: https://blog.csdn.net/qq_38148394/article/details/87921373 此功能实现使用到PHPExcel类库,PHPExcel是一个PHP类库 ...
- Sql server2008如何导入Excel文件数据?
sql server 中如何使用Excel文件导入数据?我做个测试,首先建立一个测试表(民族表) --创建一个民族表-- create table BdsNation( Uid int not nul ...
- 将 excel文件数据导入MySQL数据库中
第一步:先将Excel文件另存为文本文件(制表符分割) 第二步:将生成的txt文件另存,并修改编码格式utf8; 第三步:将文件放到指定位置,或自己想要的位置: G:\city.txt 第四步:避免创 ...
- java读取excel文件数据导入mysql数据库
这是我来公司的第二周的一个小学习任务,下面是实现过程: 1.建立maven工程(方便管理jar包) 在pom.xml导入 jxl,mysql-connector 依赖 可以在maven仓库搜索 2.建 ...
随机推荐
- GO web学习(二)
跟着b站https://space.bilibili.com/361469957 杨旭老师学习做的笔记 Response响应 ResponseWriter 包括Writer,WriterHeader, ...
- 安装Hadoop单节点伪分布式集群
目录 安装Hadoop单节点伪分布式集群 系统准备 开启SSH 安装JDK 安装Hadoop 下载 准备启动 伪分布式模式安装 配置 配饰SSH免密登录本机 测试启动 单节点安装YARN 伪分布式集群 ...
- ubuntu发行版内核源码下载
Ubuntu 发行版linux内核在哪里? 内核安装包:http://archive.ubuntu.com/ubuntu/pool/main/l/linux/ 内核源码:https://git.lau ...
- String s=new String(“hello”)的执行过程
一. 介绍 String 是Java.long包下的String类,是一个特殊的引用类型,用于表示字符串.它提供了许多方法来操作和处理字符串,比如连接.截取.查找.替换等.String类内部使用字符数 ...
- Windows安装SSH服务器
1.打开Win的设置并在设置中找到应用 2.在应用中依次选择应用和功能 可选功能 3.在可选功能中选择添加功能 (OpenSSH客户端默认已存在) 选中OpenSSH服务器后点击下方的安装 4.快捷键 ...
- 初识C语言中的typedef、define以及Status
小阿杰最近开始看数据结构啦嘿嘿嘿, 可惜小阿杰C语言功底稀薄,以此篇随笔记录一下我卑微的学习之路/苦涩/苦涩 首先define没啥好说的,在文件开头,定义一个固定不变的值. #define MAXN ...
- MySQL的索引详解
在MySQL中,常见的索引类型有以下几种: B-Tree索引: B-Tree(Balanced Tree)索引是MySQL中最常见的索引类型.它基于B-Tree数据结构,适用于等值查询.范围查询和排序 ...
- 【教程】AWD中如何通过Python批量快速管理服务器?
前言 很多同学都知道,我们常见的CTF赛事除了解题赛之外,还有一种赛制叫AWD赛制.在这种赛制下,我们战队会拿到一个或多个服务器.服务器的连接方式通常是SSH链接,并且可能一个战队可能会同时有多个服务 ...
- 去中心化组件共享方案 —— Webpack Module Federation(模块联邦)
在大型应用中, 我们可能会对其进行拆分,分成容器.主应用和多个子应用,使拆分后的应用独立开发与部署,更加容易维护.但无论是微应用.公共模块应用,都需要放到容器中才能使用. 如果多个应用之间希望资源共享 ...
- 安装部署RabbitMQ
前言 RabbitMQ是一款使用Erlang语言开发,实现AMQP(高级消息队列协议)的开源消息中间件.RabbitMQ的特点: 可靠性.支持持久化,传输确认,发布确认等保证了MQ的可靠性. 灵活的分 ...