C# 根据Excel生成树
需求:
根据Excel生成树,Excel的某些节点为属性节点,
如: 列(桩号、构件编码、测试属性1) 是列(分项工程名称) 的属性,非节点。
列(桩号、构件编码、测试属性1) 以属性的方式存在
导入的思路:
排除属性列外,所有的列从左到右,树的层级依次递增,左边列是右边列的父节点
判断一个单元格是否已添加,获取该单元格的所有父节点的名称,拼接成字符串。
如:鸡鸣隧道 的全名就是 城开高速公路,B2合同段,鸡鸣隧道
效率的优化:
1、导入第二行(或后面行)的时候,判断和第一行是否有相同的节点,有就跳过相同节点,从不同的节点处开始导入。
2、在效率低下的方法处 加上缓存
3、导入A1合同段,就只加载A1合同段,这颗树的全部节点
树的一二级节点固定的
树的类:
- public class tb_Projects
- {
- public int ProID { get; set; }
- public string ProjectName { get; set; }
- /// <summary>
- /// 编码
- /// </summary>
- public string ProjectCode { get; set; }
- public int ParentId { get; set; }
- public int? NextId { get; set; }
- public int? ProjectOrder { get; set; }
- public int IsEnabled { get; set; }
- /// <summary>
- /// 业主单位id
- /// </summary>
- public int? OwnerId { get; set; }
- /// <summary>
- /// 施工单位ID
- /// </summary>
- public int? ConstructionId { get; set; }
- /// <summary>
- /// 监理单位id
- /// </summary>
- public int? SupervisionId { get; set; }
- /// <summary>
- /// 承包单位id
- /// </summary>
- public int? ContractId { get; set; }
- /// <summary>
- /// 第几级(即在树层次中第几级,根元素级次为1,以此类推)
- /// </summary>
- public int? Level { get; set; }
- /// <summary>
- /// 数量
- /// </summary>
- public int? Quantity { get; set; }
- public int VersionIng { get; set; }
- /// <summary>
- /// 里程桩号
- /// </summary>
- public string MileageNo { get; set; }
- /// <summary>
- /// 标准编码
- /// </summary>
- public string ComponentCode { get; set; }
- /// <summary>
- /// 内部编码
- /// </summary>
- public string NComponentCode { get; set; }
- /// <summary>
- /// 流程状态
- /// </summary>
- public int TaskStatus { get; set; }
- public string FbxId { get; set; }
- /// <summary>
- /// 判断是否为单位工程
- /// </summary>
- public int IsSubunit { get; set; }
- /// <summary>
- /// 所属标段
- /// </summary>
- public string BiDSion { get; set; }
- }
Excel格式:
生成的树:
数据库:
C# 根据Excel生成树的更多相关文章
- 小功能 清单模板导入 根据Excel生成树
把代码备份一下,免得硬盘又坏了,看来已经造成心理阴影了啊. 方式一: //清单范本 public void test1() { //生成说明 var ds = ExcelHelper.ExcelToD ...
- Python操作Excel(将父子级表头生成树状结构)
import re class Node: ''' 容器,用来存储前后节点信息 ''' __slot__=[] def __init__(self,val,next_,pre,name,no): se ...
- 【造轮子】打造一个简单的万能Excel读写工具
大家工作或者平时是不是经常遇到要读写一些简单格式的Excel? shit!~很蛋疼,因为之前吹牛,就搞了个这东西,还算是挺实用,和大家分享下. 厌烦了每次搞简单类型的Excel读写?不怕~来,喜欢流式 ...
- excel 日期/数字格式不生效需要但双击才会生效的解决办法
原因: Excel2007设置过单元格格式后,并不能立即生效必须挨个双击单元格,才能生效.数据行很多.效率太低. 原因:主要是一些从网上拷贝过来的日期或数字excel默认为文本格式或特殊-中文数字格式 ...
- C# Excel导入、导出【源码下载】
本篇主要介绍C#的Excel导入.导出. 目录 1. 介绍:描述第三方类库NPOI以及Excel结构 2. Excel导入:介绍C#如何调用NPOI进行Excel导入,包含:流程图.NOPI以及C#代 ...
- Word/Excel 在线预览
前言 近日项目中做到一个功能,需要上传附件后能够在线预览.之前也没做过这类似的,于是乎就查找了相关资料,.net实现Office文件预览大概有这几种方式: ① 使用Microsoft的Office组件 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-Excel导入和导出-自定义表模导入
系列目录 前言 上一节使用了LinqToExcel和CloseXML对Excel表进行导入和导出的简单操作,大家可以跳转到上一节查看: ASP.NET MVC5+EF6+EasyUI 后台管理系统(6 ...
- C#中如何给Excel添加水印
我们知道Microsoft Excel并没有内置的功能直接给Excel表添加水印,但是其实我们可以用其他变通的方式来解决此问题,如通过添加页眉图片或艺术字的方法来模仿水印的外观.所以在这篇文章中,我将 ...
- C#中如何在Excel工作表创建混合型图表
在进行图表分析的时候,我们可能需要在一张图表呈现两个或多个样式的图表,以便更加清晰.直观地查看不同的数据大小和变化趋势.在这篇文章中,我将分享C#中如何在一张图表中创建不同的图表类型,其中包括如何在同 ...
随机推荐
- 【Unix网络编程】chapter5TCP回射服务器程序
chapter5 5.1 概述 5.2 TCP回射服务器程序:main函数 int main(int argc, char **argv) { int listenfd,connfd; pid_t ...
- JavaScript之函数,词法分析,内置对象和方法
函数 函数定义 JavaScript中的函数和Python中的非常类似,只是定义方式有点区别. // 普通函数定义 function f1() { console.log("Hello wo ...
- windows下maven的安装
1.下载maven的zip包,下载地址:http://maven.apache.org/download.cgi 2.解压到F:\maven 3.修改环境变量: MAVEN_HOME:F:\maven ...
- [work]Spring_Jdbc
封装Spring-RowMapper,使得使用更加灵活 import java.sql.ResultSet; import java.sql.SQLException; import java.uti ...
- python 日期创建dir
- 转:ArcGIS中利用ArcMap将地理坐标系转换成投影坐标系(从WKID=4326到WKID=102100)
对于非地理专业的开发人员,对与这些生涩的概念,我们不一定都要了解,但是我们要理解,凡是以经纬度为单位的都是地理坐标系,因为它归根结底是一个椭球体,只不过各个国家为了反映该国家所在区域地球的真实形状,而 ...
- Executors.newSingleThreadScheduledExecutor();线程池中放入多个线程问题
转自:https://blog.csdn.net/u012062455/article/details/78247234/
- 关于 Level 和 Promotion,其实就那么简单
曾经有读者和朋友问我:一般硅谷工作了三四年以后,会是什么 level?找工作会拿到什么 package?拿到这个问题之后,我想了想,还是没有回答.其实三四年的时间,对于曾经在同一个起点的两个人,因为际 ...
- cookies_ajax
views def test_user(request): print('start') if request.method=='POST': print('goon_test_user') user ...
- URL记录
http://orchome.com/5https://www.cnblogs.com/haozhengfei/p/2192231596ceb2ac4c22294dbd25a1ca.htmlhttps ...