【C#】【IO】【Threading】【实例】工作报表前的本地数据聚合操作

这篇具有很好参考价值的文章主要介绍了【C#】【IO】【Threading】【实例】工作报表前的本地数据聚合操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

<工作记录——Report>

报表前的数据获取操作是高重复性的,今天差不多完成了脚本,下述是代码:

  1 // See https://aka.ms/new-console-template for more information
  2 using System.IO;
  3 using System.Threading;
  4 
  5 string SN = @"C0230U25";
  6 string sourcefold = @"F:\整图图片";
  7 string flasefold = @"F:\报错";
  8 string rootPath = @"";
  9 Report r = new(rootPath);
 10 string[] foldlist = r.CreateFlaseFold(sourcefold, flasefold);
 11 //Console.WriteLine(r.FindSN(sourcefold, SN));
 12 ThreadInvote<Report> tp = new ThreadInvote<Report>(action, r, foldlist);
 13 
 14 static void action(Report r, string[] str, int num)
 15 {
 16     r.CopyLimitFold(str, num);
 17 }
 18 
 19 static void FindFalsePic()
 20 {
 21     foreach (var fold in Directory.GetDirectories(@"F:\报错\1011"))
 22     {
 23         foreach (var file in Directory.GetFiles(fold, "*.jpg"))
 24             //Console.WriteLine(file[(fold.Length+1)..]);
 25             File.Copy(file, Path.Combine(@"F:\报错\1011过杀", file[(fold.Length + 1)..]));
 26     }
 27 }
 28 
 29 //Thread t_0 = new Thread(() => r.CopyLimitFold(foldlist, 0));
 30 //Thread t_1 = new Thread(() => r.CopyLimitFold(foldlist, 1));
 31 //t_0.Start();
 32 //t_1.Start();
 33 //t_0.Join();
 34 //t_1.Join();
 35 
 36 
 37 # region 报表数据抓取类
 38 class Report
 39 {
 40     int count = 0;
 41     string rootPath;
 42     public Report(string rootPath)
 43     {
 44         this.rootPath = rootPath;
 45     }
 46 
 47     public string[] CreateFlaseFold(string sourcefold, string flasefold)
 48     {
 49         string[] foldlist = new string[4];
 50         string todaydate = Path.Combine(sourcefold, DateTime.Now.ToString("yyyy年MM月dd日"));
 51         foldlist[0] = todaydate;
 52         string yestoday = Path.Combine(sourcefold, DateTime.Now.AddDays(-1).ToString("yyyy年MM月dd日"));
 53         foldlist[1] = yestoday;
 54         string foldnamepath = Path.Combine(flasefold, DateTime.Now.ToString("MMdd"));
 55         foldlist[2] = foldnamepath;
 56         string foldnamepath_ng = String.Concat(foldnamepath, "过杀");
 57         foldlist[3] = foldnamepath_ng;
 58         if (!Directory.Exists(foldnamepath))
 59             Directory.CreateDirectory(foldnamepath);
 60         if (!Directory.Exists(foldnamepath_ng))
 61             Directory.CreateDirectory(foldnamepath_ng);
 62         return foldlist;
 63     }
 64 
 65     public void CopyLimitFold(string[] foldlist, int sw)
 66     {
 67         int count = 0;
 68         foreach (var item in
 69             Directory.GetDirectories(Directory.GetDirectories(foldlist[sw])[0]))
 70         {
 71             int limitdate = Convert.ToInt32(String.Concat("1", Directory.GetCreationTime(item).ToString("HHmm")));
 72             string ffolders = Path.Combine(foldlist[2], item[30..]);
 73             if (sw == 0 && limitdate >= 10000 && limitdate < 10800)
 74             {
 75                 if (!Directory.Exists(ffolders))
 76                     Directory.CreateDirectory(ffolders);
 77                 foreach (var fileitem in Directory.GetFiles(item))
 78                 {
 79                     File.Copy(fileitem, Path.Combine(foldlist[2], fileitem[30..]));
 80                 }
 81                 count++;
 82             }
 83             if (sw == 1 && limitdate >= 10800 || limitdate == 10000)
 84             {
 85                 //File.Copy(item, Path.Combine(foldlist[2], item[30..]));
 86                 if (!Directory.Exists(ffolders))
 87                     Directory.CreateDirectory(ffolders);
 88                 foreach (var fileitem in Directory.GetFiles(item))
 89                 {
 90                     File.Copy(fileitem, Path.Combine(foldlist[2], fileitem[30..]));
 91                 }
 92                 count++;
 93             }
 94         }
 95         if (sw == 0)
 96             Console.WriteLine($"{foldlist[sw]}:{count}");
 97         if (sw == 1)
 98             Console.WriteLine($"{foldlist[sw]}:{count}");
 99     }
100 
101     public int TotalFalseBoard()
102     {
103         foreach (var item in Directory.GetDirectories(rootPath))
104         {
105             string[] files = Directory.GetFiles(item, "*.jpg");
106             if (files.Length > 0)
107                 count++;
108         }
109         return count;
110     }
111 
112     public string FindSN(string sourcefold, string SN)
113     {
114         foreach (var item in Directory.GetDirectories(sourcefold))
115             foreach (var i_item in Directory.GetDirectories(Directory.GetDirectories(item)[0]))
116                 if (i_item.Contains(SN))
117                     return i_item;
118         return "NULL";
119     }
120 }
121 # endregion
122 
123 # region 多线程调用类
124 class ThreadInvote<T>
125 {
126     public ThreadInvote(Action<T, string[], int> action, T tt, string[] foldlist)
127     {
128         foreach (var item in Enumerable.Range(0, 2))
129         {
130             Thread t = new Thread((ThreadStart) => { action(tt, foldlist, item); });
131             t.Start();
132             t.Join();
133         }
134     }
135 }
136 #endregion
137 
138 
139 // Completed

上述代码中,关键变量分别都在顶级语句中(SN、sourcefold、falsefold)

因为业务原因,所以需要剥离多层文件夹,并精准获取指定文件夹中的所有文件然后进行拷贝,其中<多线程调用类>单纯个人觉得在主方法中重复性的创建多个Thread并启用觉得很麻烦,所以单独写了一个泛型类来简化主程序中的代码。

 

想要运行上述程序的童鞋可以通过下述Python代码来创建对应的sourcefold结构:

 1 import os
 2 
 3 # 根目录
 4 root_path = r"C:\Users\Desktop\Practice"
 5 
 6 for item in range(1, 41):
 7     # 在root_path下创建40个文件夹,1-40
 8     foldname = os.path.join(root_path, str(item))
 9     os.mkdir(foldname)
10 
11     # 每个文件夹下再创建一个文件夹,1-40,1
12     foldname_son1 = os.path.join(foldname, str(item) + f'.{item}')
13     os.mkdir(foldname_son1)
14 
15     # 再1-40,1内再创建500个文件夹,1-40,1,1-500
16     for i_item in range(1, 501):
17         foldname_son1_son = os.path.join(foldname_son1, str(i_item) + f'..{i_item}')
18         os.mkdir(foldname_son1_son)
19 
20         # 每个文件夹下创建一个jpg图片,并在1文件夹下多创建一张图
21         pic_name = os.path.join(foldname_son1_son, str(item) + '.jpg')
22         if item == 1:
23             with open(pic_name[:-4] + '1.jpg', 'w'):
24                 pass
25         with open(pic_name, 'w'):
26             pass
27 
28         # 每个文件下创建一个txt文本
29         txt_name = os.path.join(foldname_son1_son, str(item) + '.txt')
30         with open(txt_name, 'w'):
31             pass

 文章来源地址https://www.toymoban.com/news/detail-711645.html

到了这里,关于【C#】【IO】【Threading】【实例】工作报表前的本地数据聚合操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 开始开发微信小程序前的准备工作,认真看完奥

    1,小程序前端 wxml css JavaScript MINA原生小程序框架 2,数据库 云开发 云数据库 云存储 云数据库是云开发自带的数据库(json类型的弱关系型的基于MongoDB的数据库) 3,后台(云开发) 基于小程序官方自研的云开发和云函数实现后台数据的管理 后台网页使用cms(内

    2024年04月16日
    浏览(34)
  • java与es8实战之二:实战前的准备工作

    这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇是《java与es8实战》系列的第二篇,主要任务是为动手实战做好准备工作,包括这些内容 借助docker,快速部署es服务 借助docker-compose,以更简单的方式部署es集群和kibana服务 介绍实战中涉及的环境

    2024年02月11日
    浏览(35)
  • 机智的Open3D学习生活(第一集):入坑前的准备工作

    1、Open3D的开源项目地址: https://github.com/isl-org/Open3D 2、Open3D的官网地址: http://www.open3d.org/ 3、Open3D的文档地址:http://www.open3d.org/docs/latest/tutorial/visualization/cpu_rendering.html 后续我将以此文档作为蓝本,逐步学习使用和深入了解Open3D(该系列将以python作为主要开发语言) 4、o

    2024年02月04日
    浏览(42)
  • Crystal Report 水晶报表实例MVC

    using CrystalDecisions.CrystalReports.Engine; using CrystalReportDemo.Models; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Web; using System.Web.Mvc; namespace CrystalReportDemo.Controllers {     public class HomeController : Controller     {         MVCTutorialEntities db = new MVCTutorialEntities(

    2024年02月02日
    浏览(44)
  • Unity中的异步编程【5】——在Unity中使用 C#原生的异步(Task,await,async) - System.Threading.Tasks

    1、System.Threading.Tasks中的Task是.Net原生的异步和多线程包。 2、UniTask(Cysharp.Threading.Tasks)是仿照.Net原生的Task,await,async开发的一个包,该包专门服务于Unity,所以取名UnityTask,简称UniTask。 3、既然有Task了,为啥还要搞一个UniTask (1)Task可以用在PC和Android上,但是在WebGL上则会

    2023年04月17日
    浏览(48)
  • 将excel数据导入到SQL server数据库,SQL server引入导入excel报表,如何解决“未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序”问题

    目录 版本: 文章主要内容:  未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序 新版本不同的设置的地方:   SQL server2018、excel 2016 1、将excel数据导入到SQL server数据库, 2、SQL server引入导入excel报表, 3、如何解决“未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序

    2024年02月11日
    浏览(54)
  • c#处理3种json数据的实例介绍

    这篇文章主要介绍了c#处理包含数组、对象的复杂json数据的方法,,需要的朋友可以参考下 网络中数据传输经常是xml或者json,现在做的一个项目之前调其他系统接口都是返回的xml格式,刚刚遇到一个返回json格式数据的接口,通过例子由易到难总结一下处理过程,希望能帮到和

    2024年02月14日
    浏览(31)
  • C# Winfrom实例:武汉智能安检闸机数据接收和解析

    项目介绍: 本实例主要是接收安检闸机的数据解析并显示到界面上,只做功能实现,不做界面美化 硬件:闸机一个、网线一根、电脑主机 开发环境:vs2017 系统:win10 涵盖知识点:tcp通讯、文件写入、多线程,委托、类型转换等 软件操作流程: 点击开始监听按钮,8999要是未

    2024年02月19日
    浏览(35)
  • RDLC报表使用教程(VS2019+Asp.Net(C#)+iframework)

    VS2019 开发环境配置 在vs环境中,菜单扩展=管理扩展 联机中搜索 RDLC,出现MicroSoft RDLC Report Designer,如下 安装完毕后,点击右键项目(Asp.Net Web应用程序)=添加=新建项,会出现 报表、报表精灵(报表向导),如下:   新建报表后,就直接可以进行RDLC报表开发。 Web.Config里面配

    2024年02月01日
    浏览(79)
  • 学习如何在C#中轻松实现串口数据接收:清晰步骤与实例代码

      概述: 以上C#示例演示了如何使用SerialPort类实现串口数据接收。通过设置串口属性、定义数据接收事件处理程序,你可以轻松地打开串口、监听数据,并在事件处理程序中对接收到的数据进行处理。这提供了一个基本框架,可根据实际需求进行定制。 在C#中实现串口数据接

    2024年02月22日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包