zoukankan      html  css  js  c++  java
  • 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() + " ");
    }
    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:softa"); //实例化一个指定目录
    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);
    }
    }

  • 相关阅读:
    Android 浅谈相机研发
    Android线程和线程池
    android之多媒体篇(三)
    android之多媒体篇(二)
    android之多媒体篇(一)
    Android图片缩放方法
    android之BitmapFactory.Options的使用
    mac .bash_profile环境变量汇总
    免费的HTML5连载来了《HTML5网页开发实例具体解释》连载(六)媒体查询
    LeetCode
  • 原文地址:https://www.cnblogs.com/adolphyang/p/4757882.html
Copyright © 2011-2022 走看看