C# Application Excel TreeView

三章 应用

20节
客户表登陆

//动软--单表--Models
--新建.net项目--简单三层管理--DBUtity--DbHelper.cs

21节
客户表数据读取

增加 CEnterprise(企事业单位;事业),CBirthday

22-24节
客户表添加、修改、删除

;select @@IDENTITY //返回刚插入的id

25节
补充MD5

using System.Security.Cryptography;

byte[] inBytes=Encoding.Default.GetBytes(str);
MD5 md5=new MD5CryptoServiceProvider();
byte[] outBytes=md5.ComputeHash(inBytes);
string lastStr=BitConverter.ToString(outBytes).Replace("-","");

26节
Excel简介

//18数字默认右边,可以选择存储格式
Workbook--sheet--row--cell
//123前面加'123 变成以文本形式保存

net程序处理Excel的技术:
OLE Automation: 微软提供的,必须装Excel
Microsoft.Jet.OleDb: 微软提供的,不用装Excel
OpenXML: 只能处理xlsx docx pptx(为什么加个x,因为office2007及以后都支持xml打开文件,易于保存文件格式)
NPOI: 程序员自己开发的,开源; 不依赖Excel,节省了资源,没有安全性、性能的问题;
在ASP.NET中最适合,因为不用单独开一个进程就可以来处理Excel文件; 只能处理xls,不支持xlsx,(但现在新版本也可以支持xml打开的xlsx)

//百度--npoi--开源中国制作的npoi

27节
NPOI读数据

(姓名,年龄,联系方式,邮箱)
//Sheet右键改名字

//新建一个Console项目 NPOITest.csProj

//1 首先引入npoi操作的程序集
引用 NPOI.dll Ionic.Zip.dll
using NPOI.SS.UserModel; //包含对excel进行操作的方法
using NPOI.HSSF.UserModel; //包含excel每个sheet的属性

using (Stream stream = new FileStream("workbook1.xls", FileMode.Open))
{
IWorkbook workbook = new HSSFWorkbook(stream); //根据流实例化一个workbook
//Console.WriteLine(workbook.NumberOfSheets); //通过索引获得sheetName
for (int i = 0; i < workbook.NumberOfSheets;i++ )
{
ISheet sheet = workbook.GetSheetAt(i); //在指定index处获得sheet对象
Console.WriteLine(sheet.SheetName);
//获得row
//Console.WriteLine(sheet.LastRowNum);
for (int j = 0; j < sheet.LastRowNum;j++ )
{
IRow row = sheet.GetRow(j);
//获得cell
List<ICell> listICells = row.Cells; //获得行的所有cell对象
foreach(ICell cell in listICells)
{
Console.Write(cell.ToString() + "\t");
}
Console.WriteLine();
}
Console.WriteLine();
}
}

28节
NPOI写入数据

//创建一个workbook
IWorkbook workbook = new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet("如鹏"); //创建sheet
IRow row = sheet.CreateRow(0); //创建row
ICell cell = row.CreateCell(0); //创建cell
cell.SetCellValue("rocky");
cell.SetCellType(CellType.STRING); //设置cell数据类型
//
using(Stream stream=File.Open("",FileMode.OpenOrCreate))
{
workbook.Write(stream);
}
Console.WriteLine("ok");

29节
项目导出

DAL:
CustomerInfoesToExcel()
//查询数据表
//创建workbook
//创建sheet
//每个reader.Read() 或dt.Rows 创建一个行
//创建首行
IRow headerRow=sheet.CreateRow(0);
for(int i=0;i<reader.FieldCount;i++)
{
//string fileName=reader.GetName(i);
ICell cellName=headerRow.CreateCell(i);
cellName.SetCellValue(reader.GetName(i));
}
int index=1;
while(reader.Read())
{
IRow row=sheet.CreateRow(index);
for(int i=0;i<reader.FieldCount;i++)
{
ICell cell=row.CreateCell(i);
cell.SetCellValue(reader.GetValue(i).ToString());
}
index++;
}
reader.Close();
using(Stream stream=File.Open("",FileMode.OpenOrCreate))
{
workbook.Write(stream);
}

30-31节
项目导入 -----------------------------------------------------------------------------------------------------------------------(*)

public void CustomerInfoesFormExcel()
{
string sql = @"insert into T_CustomerInfo(CName,CPwd,CNumber,CGender,CCompany,CDate,CMobile,CEmail,CAddress,DelFlag)
values(@CName,@CPwd,@CNumber,@CGender,@CCompany,@CDate,@CMobile,@CEmail,@CAddress,@DelFlag)";
//SqlParameter[] param = {
// new SqlParameter(){ParameterName="@CName",Value=model.CName},...
// };

//流读取
using(Stream stream=File.Open("workbookWrite.xls",FileMode.Open))
{
IWorkbook workbook = new HSSFWorkbook(stream);
ISheet sheet = workbook.GetSheetAt(0);

string[] parameterName = new string[sheet.GetRow(0).LastCellNum - 1]; //可以拿到最外面

//执行每一行
for (int i = 0; i <= sheet.LastRowNum;i++ )
{
IRow row = sheet.GetRow(i);
//初始化sql参数
SqlParameter[] param = new SqlParameter[row.LastCellNum - 1];
for (int j = 0; j < param.Length; j++)
{
param[j] = new SqlParameter();
}

if (i == 0) //首行
{
for (int j = 1; j < row.LastCellNum; j++)
{
ICell cell = row.GetCell(j);
parameterName[j-1] = "@" + cell.StringCellValue;
}
}
else //非首行的数据行
{
for (int j = 1; j < row.LastCellNum; j++)
{
ICell cell = row.GetCell(j);
param[j - 1].ParameterName = parameterName[j - 1];
param[j-1].Value = cell.ToString();
}
SqlHelper.ExecuteNonQuery(sql, param);
}
}
}
}

32节
汉字转换拼音

Visual Studio International Pack
Readme.html 说明书

CHnConversionPinYins.cs
引用 ChnCharInfo.dll
using Microdoft.International.Converters.PinYinConverter

ChineseChar chn=new ChineseChar("如"); //实例化一个汉字字符,构造函数传入一个汉字
//foreach(var item in chn.Pinyins) //通过属性拿到拼音
//{
// Console.WriteLine(item); //(RU2贰声) (RU5没有声调) (未知拼音)
//}
string pinyin=chin.Pinyins[0].Substring(0,chin.Pinyins[0].Length-1)
Console.WriteLine(pinyin);

foreach(cahe c in str){...} //遍历str中每个字符

33节
简体转繁体

引用 ChineseConverter
using Microsoft.International.Converters.TraditionalChineseToSimplifiedConverter;

string traditionStr = ChineseConverter.Convert("闯将明月光", ChineseConversionDirection.SimplifiedToTraditional);

34节
递归初阶

//方法体自己调用自己
StackOverflowException
//例1 累加

35节
Treeview

//树状数据结构

TreeNode node=new TreeNode("Adolph")
TreeNode n1=new TreeNode("好人");
TreeNode n2=new TreeNode("帅哥");
node.Nodes.Add(n1);
node.Nodes.Add(n2);
treeView1.Nodes.Add(node);

36-37节
TreeView省市绑定、递归绑定城区

GetAreaList(int AreaPId=0) //如果传参数,则为参数值;不传参,就是0

//加载节点
private void LoadTree()
{
List<AreaFull> list = areaBll.GetAreaByAreaPid();
foreach(AreaFull area in list)
{
TreeNode node = new TreeNode(area.AreaName);
node.Tag = area.AreaId;
BindCityInfo(node,area);
treeView1.Nodes.Add(node);
}
}

//绑定城市节点
private void BindCityInfo(TreeNode node,AreaFull area)
{
List<AreaFull> list = areaBll.GetAreaByAreaPid(area.AreaId);
foreach(AreaFull city in list)
{
TreeNode nodeCity = new TreeNode(city.AreaName);
nodeCity.Tag = city.AreaId;
BindCityInfo(nodeCity,city); //可以继续绑定加载城市下一级得区
node.Nodes.Add(nodeCity);
}
}

38节
递归删除

string areaName = treeView1.SelectedNode.Text
int id = (int)treeView1.SelectedNode.Tag

//根据id删除
private void DeleteNodesById(int id)
{
//如果是省,查询所有城市
List<AreaFull> list = areaBll.GetAreaByAreaPid(id);
//遍历城市,根据每个城市id查询所有城区
foreach(AreaFull area in list)
{
DeleteNodesById(area.AreaId);
//遍历城区,根据id删除城区
}
areaBll.DeleteAreaFullById(id); //从最里面往外删除
}

39节
编辑节点

treeView1_DoubleClick()
TreeNode node=treeView1.SelectedNode;
node.BeginEdit(); //设置为可编辑状态

BtnEditNode_Click()
nodeName
AreaId
//根据id更新地区节点

40节
添加节点

//选中一个节点,通过文本框,让用户输入一个节点,把这个节点添加到该节点的子节点中

//选中节点
//获得nodeName nodeId
//插入 insert into T(AreaName,AreaPid)

41节
三层架构总结

//CRUD 增删改查+MD5
//NPOI Excel导入导出
//Treeview 树节点的增删改查
BLL中ChangePassword

homework中最后一题:

DirectoryInfo dir=new DirectoryInfo("c:\soft\a"); //实例化一个指定目录
string dirName=dir.Name; //获得目录名称
dir.GetDirectories() //获得目录下的所有直接目录
dir.GetFiles() //获得目录下的所有直接文件

//最后一题作业:---> 遍历电脑指定文件夹下所有的文件和文件夹,加载到一个树控件中图片见附件

//加载树节点
private void LoadTree()
{
DirectoryInfo dir = new DirectoryInfo(@"G:\RuPeng_YZK_150107"); //实例化这个文件夹
string dirName = dir.Name;
TreeNode nodeRoot = new TreeNode(dirName);
BindDirectoryAndFile(nodeRoot, dir);
treeView1.Nodes.Add(nodeRoot);
}

//递归绑定加载子目录和子文件,nodeRoot是父节点
private void BindDirectoryAndFile(TreeNode nodeRoot, DirectoryInfo dir)
{
//获得子目录集合
DirectoryInfo[] directs = dir.GetDirectories();
foreach (DirectoryInfo direct in directs)
{
TreeNode node = new TreeNode(direct.Name);
nodeRoot.Nodes.Add(node);
//每一级子目录加入父节点后调用下一级
BindDirectoryAndFile(node, direct);
}
//获得子文件集合
FileInfo[] files = dir.GetFiles();
foreach (FileInfo file in files)
{
TreeNode node = new TreeNode(file.Name);
nodeRoot.Nodes.Add(node);
}
}

posted on 2015-08-25 16:39 AdolphYang 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/adolphyang/p/4757882.html

C# Application Excel TreeView相关推荐

  1. 调用Excel 的Excel.Application失败的问题分析

    Excel提供了对外的API调用,可以用来实例化一个excel的instance,具体的调用方法是: #define EXCEL_APPLICATION_NAME _T("Excel.App ...

  2. c# 做Excel转PDF的时候application.Workbooks.Open 打开失败

    此处将我引用的代码贴出来: private bool ExceltoPDF(string sourcePath, string targetPath, Excel.XlFixedFormatType ...

  3. 利用python编写exe应用,实现excel文件输出建表sql文件。

    目录 一.excel文件内容如下: 二.生成如下sql: 三. 思路: 1.设计界面 2.界面分模块设计 2.1 模块一(数据库选择) 点击选择按钮会触发command后面的函数,同时会相应的返回va ...

  4. C#操作OFFICE一(EXCEL)

    C#操作Excel!     public class ImportExportToExcel     {         private string strConn ;               ...

  5. C# 实现Oracle中的数据与Excel之间的转换

    最近项目要求实现数据库之间数据在各个数据库之间导入导出,在此做个笔记 1. 将Oracle中的表导入到Excel中,反之亦然 private static readonly string connec ...

  6. C#如何在Form中嵌入并且操作Excel表格

    网上比较多讲述如何操作excel表的文章,但都是启动excel的窗口来打开excel数据文件.有时候需要把excel表嵌入到自己程序的form中,给客户一个不用切换窗口的操作界面,似乎更好.这在vc中 ...

  7. C#操作excel(多种方法比较)

    我们在做excel资料的时候,通常有以下方法. 一.导入导出excel常用方法: 1.用查询表的方式查询并show在数据集控件上. 代码 public static string strCon = & ...

  8. excel html modify,在Excel 2010中修改Series对象上的Z-index(Modify Z-index on Series object in Excel 2010)...

    在Excel 2010中修改Series对象上的Z-index(Modify Z-index on Series object in Excel 2010) 我正在使用excel 2010. 我有一个 ...

  9. python 图表_python导出excel charts图表

    在Excel vba将chart另存为图片篇中讲了如何通过vba宏将excel 中的chart图表导出为的图片,本篇讲下如何使用纯python代码将excel 中的图表导出为图片.这里需要使用的模块有 ...

  10. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】)...

     本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较    (三)SSIS的简介    (四)数据库中存储过程示例(SSIS应用需要) (五)Excel模板的制作(这步这么简单,稍微介 ...

最新文章

  1. python语法基础题输出倒三角图案,【趣味shellamp;amp;python】倒三角控制台输出图形...
  2. 18岁双料竞赛金牌得主邓明扬:我只是数学初学者,求在MIT“活”下去
  3. Python-第一个Python程序
  4. WordPress主题LensNews1.8模板源码,WP多功能新闻积分商城主题
  5. 【ElasticSearch】Es 源码之 GatewayModule GatewayService 源码解读
  6. SpringCloud学习笔记024---SpringBoot中使用大部分公用的配置记录
  7. 如何设置并使用运行在远程服务器上jupyter notebook
  8. 【金融】【python】处理表格(*.xlsx)形式的期货数据
  9. 腾讯云首次披露虚拟化技术发展线路图,看好轻量级虚拟化的潜力
  10. S3上备份的json文件转存成parquet文件
  11. 【性能测试】:操作NMON的shell脚本
  12. Hibernate【缓存】知识要点
  13. 软件过程与管理复习(九)
  14. 打开网址自动跳转 php,HTML网页自动跳转的5种方法
  15. FFmpeg 视频裁剪
  16. React hooks组件通信
  17. 【Python讲义】WEEK 4
  18. 你的时间都去哪了?(一)数据分析指标
  19. kal虚拟机统下安装open-vmware-tools
  20. 【Hack The Box】windows练习-- Silo

热门文章

  1. 修正版-Android模拟器 SDK 2.2 2.3 下载与安装教程(修改2.1版本的问题...
  2. 【批注】技术选型 -- 绘图 DrawGraphics
  3. 新生干货!--开学季,我想对大一大二同学说:
  4. 学习笔记:RNN基本结构与Char RNN文本生成
  5. 这样学上位机,是不是有意思多了
  6. 广东《国土资源系统地质灾害突发事件应急管理》学习摘要
  7. Kubernetes 中部署 NFS Provisioner 为 NFS 提供动态分配卷(shell脚本)
  8. unity3d 贪吃蛇移动
  9. IP地址变更后CICS和CTG的相应修改
  10. Python 读取PostgreSQL的geometry字段,以及解决遇到的问题