将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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • EPPlus 使用小结

    EPPlus 使用小结文章目录简介导入导出简单导出样式格式化其他总结简介EPPlus是一个使用OpenOfficeXML(xlsx)文件格式,能读写Excel2007/2010文件的开源组件,在导出Excel的时候不需要电脑上安装office,它的一个缺点就是不支持导出2003版的Excel(xls)。导入这部分相对简单,直接看下代码:using(ExcelPackagepackage=newExcelPackage(existingFile)){ExcelWorksheetworksh

    2022年6月15日
    747
  • 百度云学习资源整合

    百度云学习资源整合关注微信公众号《IT技术资源共享》获取更多资源!微信号:feng1376311650或者扫二维码关注获取下面全部资源:python:【0001】Python安装包,教程文档,工具包链接:http://pan.baidu.com/s/1hsnHizM密码:9×03【0002】Python基础到高级视频教程链接:http://pan.baidu.com/s/1qYE5nOS密码:v0qfjava:【1101】java项目视频20套链接:…

    2022年5月11日
    99
  • 海思Hi3798MV310芯片处理器参数介绍「建议收藏」

    海思Hi3798MV310芯片处理器参数介绍「建议收藏」Hi3798MV310是用于IPTV/OTT机顶盒市场的支持4KP60解码的超高清高性能SOC芯片。集成4核64位高性能CortexA53处理器和多核高性能2D/3D加速引擎;支持H.265/AVS24Kx2K@P6010bit超高清视频解码,高性能的H.265高清视频编码,HDR视频解码及显示,HDR转SDR,BT.2020,Dolby和DTS音频处理;内置USB2.0…

    2022年6月28日
    192
  • 云 云计算_openapi开发接口

    云 云计算_openapi开发接口http://www.cnblogs.com/skyme/p/3435565.html介绍OpenAPI即开放API,也称开放平台。所谓的开放API(OpenAPI)是服务型网站常见的一种应用,网站的服务商将自己的网站服务封装成一系列API(ApplicationProgrammingInterface,应用编程接口)开放出去,供第三方开发者使用,这种行为就叫做开放网站的API,所

    2022年9月27日
    0
  • 风扇pwm控制的基本原理_pwm风扇不转

    风扇pwm控制的基本原理_pwm风扇不转PWM:占空比,脉冲调制风扇:需要脉冲去控制,因为其中具有磁场,需要提供磁场其转动它,即高低电平。

    2022年8月3日
    4
  • smarty怎么用_item怎么用

    smarty怎么用_item怎么用1、简介含义:Smarty是PHP的一个引擎模板,可以更好的进行逻辑与显示的分离,即我们常说的MVC,这个引擎的作用就是将C分离出来。环境需求:PHP5.2或者更高版本我使用的环境是:PHP5.

    2022年8月5日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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