QueryInfo dataInfo = new QueryInfo();
dataInfo.CustomSQL = $@"
select t1.name name,t1.url url from sys_menu t1
start with t1.parent_id =
(
select t2.id from sys_menu t2 where t2.name ='交易源数据' )
connect by t1.parent_id=t1.id
";
var descpsInfo = new QueryInfo(); var dataTable = Dao.ExcuteDataSet(dataInfo).Tables[];
foreach (DataRow row in dataTable.Rows)
{
var china_name = row["name"]==null?"":row["name"].ToString();
var en_name = Holworth.Utility.ListAndTableExtension.ConvertToTableColumnName
(row["url"].ToString().Split('/')[row["url"].ToString().Split('/').Length - ].Replace("Manage.aspx", ""));
descpsInfo.CustomSQL = string.Format(@"
select (select t.COMMENTS from all_tab_comments t where t.TABLE_NAME='{0}' AND t.OWNER='NETHRA') tComments,
tt.TABLE_NAME ,
tt.COLUMN_NAME ,
(select t2.COMMENTS cComments from all_col_comments t2 where t2.column_name=tt.column_name and t2.OWNER='NETHRA' AND T2.TABLE_NAME='{0}') cComments,
tt.DATA_TYPE,tt.DATA_LENGTH,tt.DATA_PRECISION from all_tab_columns tt where tt.OWNER='NETHRA' AND TT.TABLE_NAME='{0}'
",en_name); //descpsInfo.CustomSQL=string.Format(descpsInfo.CustomSQL,en_name);
var dic = Dao.ExcuteDataSet(descpsInfo).Tables[].AsEnumerable().Select
(
x => new
{
tableName = x["TABLE_NAME"]==null?"":x["TABLE_NAME"].ToString(),
tComments = x["tcomments"]==null?"":x["tcomments"].ToString(),
columnsName = x["COLUMN_NAME"]==null?"":x["COLUMN_NAME"].ToString(),
cComments = x["cComments"]==null?"":x["cComments"].ToString(),
dataType = x["DATA_TYPE"].ToString(),
columnDataLength = x["DATA_LENGTH"].ToString(),
columnDataPrecious = x["DATA_PRECISION"].ToString(), } ).ToList(); //1.创建excel文件
string file = @"C:\Users\admin\Desktop\本周纪要\3.xlsx"; XSSFWorkbook workbook = null;
if (!File.Exists(file))
{
workbook = new XSSFWorkbook();
}
else
{ workbook = new XSSFWorkbook(File.OpenRead(file));
} // 新建一个Excel页签
//1.1创建固定部分前两行 var sheet = workbook.CreateSheet(china_name); IRow row1 = sheet.CreateRow(); //创建sheet页的第0行(索引从0開始)
int start = ;
//1.1.1表头
row1.CreateCell(, CellType.String).SetCellValue("中文表名");
row1.CreateCell(, CellType.String).SetCellValue(china_name);
row1.CreateCell(, CellType.String).SetCellValue("英文表名");
row1.CreateCell(, CellType.String).SetCellValue(en_name);
row1.CreateCell(, CellType.String).SetCellValue("主键");
row1.CreateCell(, CellType.String).SetCellValue("备注"); //1.1.2列头
IRow row2 = sheet.CreateRow();
row2.CreateCell(, CellType.String).SetCellValue("英文名称");
row2.CreateCell(, CellType.String).SetCellValue("中文名称");
row2.CreateCell(, CellType.String).SetCellValue("数据类型");
row2.CreateCell(, CellType.String).SetCellValue("是否为空");
row2.CreateCell(, CellType.String).SetCellValue("");
row2.CreateCell(, CellType.String).SetCellValue(""); using (Stream stream =File.OpenWrite(file))
{ foreach (var item in dic)
{
var columnName = item.columnsName;
var cComment = item.cComments;
var cDataType = item.dataType;
var cLength = item.columnDataLength;
var cPrecious = item.columnDataPrecious;
//是否为空需要人判断默认为空
IRow tmpRow = sheet.CreateRow(start++);
//上述信息写入excel文件
tmpRow.CreateCell(, CellType.String).SetCellValue(columnName);
tmpRow.CreateCell(, CellType.String).SetCellValue(cComment);
tmpRow.CreateCell(, CellType.String).SetCellValue(cDataType);
tmpRow.CreateCell(, CellType.String).SetCellValue("Y");
tmpRow.CreateCell(, CellType.String).SetCellValue("");
tmpRow.CreateCell(, CellType.String).SetCellValue(""); }
start = ;
workbook.Write(stream); //将这个workbook文件写入到stream流中 } }

NPOI读写Excel sheet操作的更多相关文章

  1. NPOI对Excel的操作(Sheet转DataTable、List<T>)

    通过NPOI对Excel进行操作,这里主要是读取的操作.封装到ExcelHelper操作类中. 1 using System.Collections.Generic; 2 using NPOI.HSS ...

  2. NPOI读写Excel

    1.整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表):Sheet:行:Row:单元格Cell. 2.NPOI是POI的C#版本,NPOI的行和列的index都是从0开始 ...

  3. 【转】NPOI读写Excel

    1.整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表):Sheet:行:Row:单元格Cell. 2.NPOI是POI的C#版本,NPOI的行和列的index都是从0开始 ...

  4. NPOI读写Excel【转载】

    参考示例:https://www.cnblogs.com/luxiaoxun/p/3374992.html 感谢! 1.整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表): ...

  5. Perl读写Excel简单操作

    Perl读写Excel简单操作 使用模块 Spreadsheet::ParseExcel Spreadsheet::WriteExcel 读Excel #!/usr/bin/perl -w use s ...

  6. C#NPOI对Excel的操作、导入导出时异常处理、最全的NPOI资料在这里~

    一.Excel理论知识 最新版NPOI2.4.1链接:https://pan.baidu.com/s/1iTgJi2hGsRQHyw2S_4dIUw  提取码:adnq • 整个Excel表格叫做工作 ...

  7. NPOI - .NET Excel & Word操作组件

    概要 NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目. NPOI是构建在POI 3.x版本之上的,它可以在没有安装Offi ...

  8. C#使用NPOI读写excel

    本帖内容来自网络+自己稍作整理,已找不到原贴,侵删 个人比较习惯用NPOI操作excel,方便易理解.在宇宙第一IDE(笑)——VS2017中插入NPOI就很方便: 首先安装NPOI: 然后在.cs文 ...

  9. NPOI读写Excel组件封装Excel导入导出组件

    后台管理系统多数情况会与Excel打交道,常见的就是Excel的导入导出,对于Excel的操作往往是繁琐且容易出错的,对于后台系统的导入导出交互过程往往是固定的,对于这部分操作,我们可以抽离出公共组件 ...

随机推荐

  1. GC之九--gc调优

    目标 满足应用的响应时间和吞吐量需求,尽量减少GC对应用的影响 原则 大部分时候都不需要调优GC,只需配置-Xms,-Xmx即可,JVM会自动进行调整 先满足响应时间需求,再满足吞吐量需求 FullG ...

  2. sklearn: TfidfVectorizer 中文处理及一些使用参数

    TfidfVectorizer可以把原始文本转化为tf-idf的特征矩阵,从而为后续的文本相似度计算,主题模型,文本搜索排序等一系列应用奠定基础.基本应用如: #coding=utf-8 from s ...

  3. HDU-1937题解

    一.题意 一个N*M的矩形,点表示空地,X表示非空地,给你一个数字k,让你在这N*M的区域内找出一个空地数量不小于k且面积最小的矩形.输出矩形的面积. PS:原题的题意是在难懂啊. 二.思路 1.朴素 ...

  4. node的socket.io的之基本使用方法.

    使用socket.io的使用创建一个socket.io服务器即可.但是该服务器依赖于一个已经创建的http服务器. 在http服务器运行之后,使用listen方法为该http服务器附加一个socket ...

  5. 5月15日上课笔记-js中 location对象的属性、document对象、js内置对象、Date事件对象、

    location的属性: host: 返回当前主机名和端口号 定时函数: setTimeout( ) setInterval() 二.document对象 getElementById(); 根据ID ...

  6. Oracle数据库学习笔记(一)

      Oracle的体系结构大体上分为两部分:Instance(实例)和Database(数据库). Instance(实例) :在Oracle Instance中主要包含了SGA以及一些进程(例如:P ...

  7. UVA-11292Dragon of Loowater

    /* The Dragon of Loowater Once upon a time, in the Kingdom of Loowater, a minor nuisance turned into ...

  8. SWFUpload初体验 For Struts1.x

    SWFUpload是一个客户端文件上传工具,最初由Vinterwebb.se开发,它通过整合Flash与JavaScript技术为WEB开发者提供了一个具有丰富功能继而超越传统<input ty ...

  9. Unknown picture file extension

    Image1.Picture.LoadFromFile('aaa.jpg'); Project Project1.exe raised exception class EInvalidGraphic ...

  10. c++builder 解压缩

    c++builder  解压缩  TZCompressionStream  TZDecompressionStream #include <System.ZLib.hpp> void __ ...