zoukankan      html  css  js  c++  java
  • 读取xml并将节点保存到Excal

    using NPOI.HPSF;
    using NPOI.HSSF.UserModel;
    using NPOI.SS.UserModel;
    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.IO;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows.Forms;
    using System.Xml;
    using System.Xml.Schema;
    
    namespace myXMLReader
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }
    
            private void button1_Click(object sender, EventArgs e)
            {
                treeResult.Nodes.Clear();
                readXml();
            }
    
            private void readXml()
            {
                // todo
                String sourcePath = "f:/test.xml";
    
                System.Xml.XmlDocument sourceXml = new XmlDocument();
                try
                {
                    sourceXml.Load(sourcePath);
                }
                catch (XmlException e)
                {
                    StringBuilder sb = addRootToXml(sourcePath);
                    sourceXml.LoadXml(sb.ToString());
                }
                catch (Exception e)
                {
                    return;
                }
    
                foreach (XmlNode rootNode in sourceXml.ChildNodes)
                {
                    if (rootNode.NodeType == XmlNodeType.Element)
                    {
                        TreeNode tNode = new TreeNode(rootNode.Name);
                        readChildNode(rootNode, tNode);
                        treeResult.Nodes.Add(tNode);
                    }
                }
    
    
                creatToExcel();
            }
    
            private void readChildNode(XmlNode node, TreeNode tNode)
            {
                foreach (XmlNode childNode in node.ChildNodes)
                {
                    if (childNode.NodeType != XmlNodeType.Element)
                    {
                        continue;
                    }
                    TreeNode tChildNode = new TreeNode(childNode.Name);
                    tNode.Nodes.Add(tChildNode);
                    if (childNode.HasChildNodes)
                    {
                        readChildNode(childNode, tChildNode);
                    }
                }
            }
            private StringBuilder addRootToXml(string path)
            {
                TextReader reader = File.OpenText(path);
                StringBuilder sb = new StringBuilder(reader.ReadToEnd());
                sb.Insert(0, "<XML>");
                sb.Append("</XML>");
                return sb;
            }
    
            private int writeRowIndex = 1;
            private void creatToExcel()
            {
                int startColumn = 1;
    
                HSSFWorkbook hssfworkbook = new HSSFWorkbook();
    
                DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
                dsi.Company = "NPOI Team";
                hssfworkbook.DocumentSummaryInformation = dsi;
    
                SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
                si.Subject = "NPOI SDK Example";
                hssfworkbook.SummaryInformation = si;
    
                ISheet sheet = hssfworkbook.CreateSheet("Sheet1");
    
                writeNodeToExcel(sheet, treeResult.Nodes[0], startColumn);
    
                FileStream file = new FileStream(@"f:/test.xls", FileMode.Create);
                hssfworkbook.Write(file);
                file.Close();
    
            }
    
            private void writeNodeToExcel(ISheet sheet, TreeNode node, int columnIndex)
            {
                IRow row = sheet.CreateRow(getRow());
                ICell cell = row.CreateCell(columnIndex);
                cell.SetCellValue(node.Text);
                for (int i = 0; i < node.Nodes.Count; i++)
                {
                    writeNodeToExcel(sheet, node.Nodes[i], columnIndex + 1);
                }
            }
    
            private int getRow()
            {
                return writeRowIndex++;
            }
        }
    }

    最近需要一个读取xml,将节点写入Excel的功能,还没有完善,暂时记录一下。

  • 相关阅读:
    代码重构编译---make
    clickhouse日期函数
    连续登陆天数+最大登陆天数
    clickhouse基本使用
    数组
    CK优化
    Hive查询优化~布隆过滤器使用
    Presto常见问题优化
    Presto原理解析
    几种排序说明
  • 原文地址:https://www.cnblogs.com/qiangwei/p/4297730.html
Copyright © 2011-2022 走看看