将Excel转换为word_excel如何将横排变成竖排

将Excel转换为word_excel如何将横排变成竖排本次转换用到了NPOI里面的方法,会经过封装成为dll,在.net平台和unity都测试通过。下面主要讲一下思路:1.将表格读取为DataTable类型2.z

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 

本次转换用到了NPOI里面的方法,会经过封装成为dll,在.net平台和unity都测试通过。下面主要讲一下思路:

1.将表格读取为DataTable类型

2.逐行读取DataTable的内容

3.根据读取到内容生成对应的XML表即可。

下面讲述一下具体的实现:

在ReadTable中进行路径设置

public class ReadTable
    {
        string tablepath = "";
        public ReadTable(string  path)
        {
            tablepath = path;
        }

        public DataTable TableToDataTable()
        {
            DataTable  table = new DataTable();
            if (tablepath == ""|| tablepath == string.Empty)
            {
                return null;
            }
            else
            {

                if (File.Exists(tablepath))
                {
                    ExcelAnalysis excel = new ExcelAnalysis();
                    table= excel.ExcelToDataTable(tablepath, false);
                }
                else
                {
                    table = null;
                }
                return table;
            }
        }

    }

ExcelAnalysis这个类里面的方法,将表格转换为DataTable

using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System;
using System.Data;
using System.IO;
namespace TableToXml
{
    class ExcelAnalysis
    {

        /// <summary>
        /// 将excel导入到datatable
        /// </summary>
        /// <param name="filePath">excel路径</param>
        /// <param name="isColumnName">第一行是否是列名</param>
        /// <returns>返回datatable</returns>
        public DataTable ExcelToDataTable(string filePath, bool isColumnName)
        {
            DataTable dataTable = null;
            FileStream fs = null;
            DataColumn column = null;
            DataRow dataRow = null;
            IWorkbook workbook = null;
            ISheet sheet = null;
            IRow row = null;
            ICell cell = null;

            int startRow = 0;
            try
            {
                using (fs = File.OpenRead(filePath))
                {
                  
                    if (filePath.IndexOf(".xlsx") > 0)
                    {
                        workbook = new XSSFWorkbook(fs);
                    }

                  
                    else if (filePath.IndexOf(".xls") > 0)
                    {
                        workbook = new HSSFWorkbook(fs);
                    }

                    if (workbook != null)
                    {
                        if (workbook.NumberOfSheets > 3)
                        {
                            sheet = workbook.GetSheetAt(4);//读取第三个sheet,也能循环读取每个sheet            
                        }
                        else
                        {
                            sheet = workbook.GetSheetAt(0);//自己的读取默认的第一个           
                        }


                        dataTable = new DataTable();
                        if (sheet != null)
                        {
                            int rowCount = sheet.LastRowNum + 1;//+1 包括列名的行,总行数

                            if (rowCount > 0)
                            {
                                IRow firstRow = sheet.GetRow(0);//第一行
                                int cellCount = firstRow.LastCellNum;//列数

                                //构建datatable的列
                                if (isColumnName)
                                {
                                    startRow = 0;//要读取列名则=0 否则=1
                                    for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
                                    {
                                        cell = firstRow.GetCell(i);
                                        if (cell != null)
                                        {
                                            if (cell.StringCellValue != null)
                                            {
                                                column = new DataColumn(cell.StringCellValue);
                                                dataTable.Columns.Add(column);
                                            }
                                        }
                                    }
                                }
                                else
                                {
                                    for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
                                    {
                                        column = new DataColumn("column" + (i + 1));
                                        dataTable.Columns.Add(column);
                                    }
                                }

                                //填充行
                                for (int i = startRow; i < rowCount; ++i) //要读取列名则i<rowCount 否则i <= rowCount
                                {
                                    row = sheet.GetRow(i);
                                    if (row == null) continue;

                                    dataRow = dataTable.NewRow();
                                    for (int j = row.FirstCellNum; j < cellCount; ++j)
                                    {
                                        cell = row.GetCell(j);
                                        if (cell == null)
                                        {
                                            dataRow[j] = "";
                                        }
                                        else
                                        {
                                            //CellType(Unknown = -1,Numeric = 0,String = 1,Formula = 2,Blank = 3,Boolean = 4,Error = 5,)
                                            switch (cell.CellType)
                                            {
                                                case CellType.Blank:
                                                    dataRow[j] = "";
                                                    break;
                                                case CellType.Numeric:
                                                    short format = cell.CellStyle.DataFormat;
                                                    //对时间格式(2015.12.5、2015/12/5、2015-12-5等)的处理
                                                    if (format == 14 || format == 31 || format == 57 || format == 58)
                                                        dataRow[j] = cell.DateCellValue;
                                                    else
                                                        dataRow[j] = cell.NumericCellValue;
                                                    break;
                                                case CellType.String:
                                                    dataRow[j] = cell.StringCellValue;
                                                    break;
                                            }
                                        }
                                    }
                                    dataTable.Rows.Add(dataRow);
                                }
                            }
                        }
                    }
                    else
                    {
                      // ("文件打开失败,请关闭文档");
                    }
                }
              
                return dataTable;
            }
            catch (Exception e)
            {
           
                if (fs != null)
                {
                    fs.Close();
                }
                return null;
            }
        }
      
    }



}

DataTableToXml 是将读取到的数据源转换为XML,并输出

using System;
using System.Data;
using System.Xml;

namespace TableToXml
{
    /// <summary>
    /// 将读取到的datatable存储到XML中
    /// </summary>
   public class DataTableToXml
    {
        DataTable dataTable;
        string xmlPath;
        /// <summary>
        /// 实例化对象
        /// </summary>
        /// <param name="dtb">自行加载的table</param>
        /// <param name="outPath">Xml的输出路径,不填默认输出在桌面上</param>
        public DataTableToXml(DataTable dtb, string outPath="")
        {
            if (outPath==""|| outPath==null)
            {
                outPath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
            }
            
            dataTable = dtb;
            xmlPath = outPath;
        }
  

        /// <summary>
        /// 根据数据源生成Xml
        /// </summary>
        /// <param name="path">XML文件的输出路径</param>
        /// <param name="outname">XML文件的输出文件名</param>
        /// <param name="rootname">跟节点的名字</param>
        private void CreateXml(string path,string outname="test",string rootname="root")
        {
            XmlDocument document = new XmlDocument();//创建XmlDocument对象

            XmlDeclaration declaration = document.CreateXmlDeclaration("1.0", "UTF-8", "");//xml文档的声明部分
            document.AppendChild(declaration);       
            XmlElement root = document.CreateElement(rootname);//根节点
            document.AppendChild(root);
            if (dataTable!=null)
            {
                DataRow[] drs = dataTable.Select();
              
                for (int i = 0; i < drs.Length; i++)
                {//行
                    XmlElement zwerks = document.CreateElement("Rows" + i);
                    root.AppendChild(zwerks);
                    for (int j = 0; j < dataTable.Columns.Count; j++)
                    {//列
                      
                        XmlElement tab= document.CreateElement("coloumns"+j);
                         tab.InnerText = drs[i][j].ToString();
                        zwerks.AppendChild(tab);
                    }
                }

            }
            document.Save(path+ outname + ".xml");//将生成好的xml保存到.xml文件中
        }
        /// <summary>
        /// 将datatable生成Xml,默认存放在桌面上
        /// </summary>
        public void DtoXml(string path)
        {
            CreateXml(path);
        }
    }
}

里面的所有变量都需要在实例化的时候进行赋值

在.net中这样调用即可将Excel转换为word_excel如何将横排变成竖排在Unity中可将编译后的dll放置在unity 的Plugins文件夹下使用,同样能达到效果,具体如下:将Excel转换为word_excel如何将横排变成竖排

最后我已经将所有需要的dll打包,放置在CSDN了,5个币就可下载(真不贵,我前前后后两天呢),今天六一,能不能赚个棒棒糖呢?如果你没有币可以私信我哦,给你发!!!

下载链接如下:https://download.csdn.net/download/mo_qi_qi/19320074

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/171952.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • xshell如何激活_xftp6使用教程

    xshell如何激活_xftp6使用教程市面上连接服务器的客户端有很多,有免费的,也有收费的。有国产的也有非国产的。每个人使用的都不一样。很多也使用过,比如putty免费的,但是在我使用看来,使用一会就卡顿住了,最后就是需要重新连接,怎么用都不是很方便,最后还是的使用回来xshell和xftp。下面就来演示下如何安装xshell和xftp。首先是下载xshell和xftp的软件安装包。其实下载这个安装包是非常简单的,但是不简单的是如何下载一个真的能用的安装包。其次就是安装了。安装其实也是非常的简单的。下一步,下一步就可以完成.

  • <Javascript>浅谈js“三元表达式” (三元运算符)

    <Javascript>浅谈js“三元表达式” (三元运算符)前言各位大神,大家好,相约周三。我们又见面了。众所周知,三元表达式在代码量上比if…else语句更简洁一些。但是博主刘少在可读性上更加偏向于if…else语句。三元表达式不仅在js中使用,在很多后台程序语言,比如java、php中都有使用,不过在js中对于三元表达式的要求貌似要松很多。废话不多说。下面一起看看三元表达式。三元表达式素质N连问首先为什么叫三元表达式?顾…

  • staruml使用方法(对讲机按键使用说明)

    综述StarUML是一种生成类图和其他类型的统一建模语言(UML)图表的工具。这是一个用Java语言描述的创建类图的简明手册。StarUML(简称SU),是一种创建UML类图,并能够自动生成Java的“stubcode”的工具。SU也可以做JAVA逆向工程,以产生相应的UML图表。在本教程中,我们将使用SU设计一个pizza饼。执行下列步骤,可以创建如下面所示的UML图。SU可以生…

  • gis可视化的方法_gis可视化分析

    gis可视化的方法_gis可视化分析前言从去年开始无脑接触Cesium三维GIS可视化,入坑之后一直到到现在,其实已经写了多个项目了,中间也遇到了很多坑点,很早就想分享其中所获了,只是觉得不太专业而且没有太多时间,…

  • python下载hashlib命令_python之hashlib模块[通俗易懂]

    python下载hashlib命令_python之hashlib模块[通俗易懂]importhashlib#md5加密工具,md5是不可逆的,所以只能比较密文,不能比较明文,python中不仅仅提供md5加密方法,还提供sha1,sha224,sha256,sha384,sha512,MD5加密算法test_md5=hashlib.md5()test_md5.update(bytes(‘123′,encoding=’utf-8’))ret=test_md5.hexd…

  • jq正则表达式_JAVA 正则表达式

    jq正则表达式_JAVA 正则表达式一、JavaScript正则表达式正则表达式(英语:RegularExpression,在代码中常简写为regex、regexp或RE)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式。搜索模式可用于文本搜索和文本替换。什么是正则表达式?正则表达式是由一个字符序列形成的搜索模式。当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容。正则表达式可以是一个简单的字符,或一个更…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号