读取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的功能,还没有完善,暂时记录一下。

时间: 2024-10-09 20:43:43

读取xml并将节点保存到Excal的相关文章

读取XML某一节点

先看XML文档: <?xml version="1.0" encoding="utf-8" ?> <NewDataSet> <Table> <id>000_bt_001</id> <message>クリア</message> </Table> <Table> <id>000_bt_002</id> <message>レンジ&

读取XML某一个节点 条件筛选

<?xml version="1.0" encoding="utf-8" ?> - <area Country="China"> - <province ID="1" provinceID="110000" province="北京市"> - <City CityID="110100" City="市辖区"

java中XML操作:xml与string互转、读取XML文档节点及对XML节点增删改查

一.XML和String互转: 使用dom4j程式变得很简单 //字符串转XML String xmlStr = \"......\"; Document document = DocumentHelper.parseText(xmlStr); // XML转字符串 Document document = ...; String text = document.asXML(); //这里的XML DOCUMENT为org.dom4j.Document 二.读取XML文档节点: pack

C#中读取xml文件指定节点

目录(?)[-] XmlDocumentSelectSingleNode方法的使用 XmlDocumentSelectNodes方法的使用 通过节点属性查找指定节点 参考:Select XML Nodes by Name 假设xml文件内容是 [c-sharp] view plaincopyprint? <?xml version="1.0" encoding="utf-8"?> <Workflow> <Activity> <

.net中读取xml文件中节点的所有属性信息

功能描述: 将数据以xml的格式记录成配置文件,需要获取配置文件中的数据时,则获取对应的配置文件,读取配置文件里对应节点的所有属性. 逻辑实现: 1.将数据配置好在xml文件中. 2.获取xml文件中所有对应的节点. 3.遍历每个节点,获取该节点所有的属性值. 4.将属性值赋到设计的节点类中. 具体实现: 实现效果

C# 读取XML的CDATA节点内容.

昨天读取了以下XML, 之前没有读取过类似的格式,用一种比较笨的方法读取的,记录下<?xml version="1.0"?> <response> <srvver>1.0</srvver> <srvcode>000</srvcode> <payload> <param type="XML" key="data"> <![CDATA[ <Re

C#从数据库读取数据到DataSet并保存到xml文件

using System; using System.Data; using System.Xml; using System.Data.SqlClient; using System.IO; public class TestWriteXML { public static void Main() { String strFileName = c:/temp/out.xml; SqlConnection conn = new SqlConnection(server=localhost;uid

Java获取XML节点总结之读取XML文档节点

dom4j是Java的XML API,用来读写XML文件的.目前有很多场景中使用dom4j来读写xml的.要使用dom4j开发,需要下载导入dom4j相应的jar文件.官网下载:http://www.dom4j.org/dom4j-1.6.1/github下载:http://dom4j.github.io/下载解压之后如图所示: 我们只需要把dom4j-1.6.1.jar文件构建到我们开发项目中就可以了. 下面就以Eclipse创建java项目的构建方法为例说明:声明:本Java项目的开发环境J

c#读取XML多级子节点

string xmlFilePath = "D:\\log_xml\\MarInfo.xml"; //Server.MapPath(@"相对路径如/xml/test.xml"); XmlDocument doc = new XmlDocument(); doc.Load(xmlFilePath);//加载XML文件 string rst = ""; //使用xpath表达式选择文档中所有的student子节点 XmlNodeList studen