使用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文件数据,匹配时间并显示

上一篇:标题: 连接到服务器 ------------------------------ 无法连接到 DESKTOP-J6I1UIC\SQLEXPRESS1。 ------------------------------ 其他信息: 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。


下一篇:linux安装python