在我们的工作中可能会需要到让execl表格转换成xml文件来使用,这样程序读取数据来也比较方便

  下面就写一个小程序来实现execl表格转换成xml文件来使用

  

  会使用到的知识点如下

  1:引用第三方Execl库

  如图:我使用的

  添加引用的步骤如下

  

  

  然后指定库文件的路径就行!

  我是放在了应用程序的当前目录下了。

  2:Directory类   命名空间System.IO

  公开用于通过目录和子目录进行创建、移动和枚举的静态方法。此类不能被继承

  主要用到以下方法:

  GetCurrentDirectory()   获取应用程序的当前工作目录

  public static string[] GetFiles(  string path )    返回指定目录中文件的名称(包括其路径)。

  publicstaticstring[] GetFiles(  string path,  string searchPattern )    返回指定目录中与指定的搜索模式匹配的文件的名称(包含其路径)

  3:Path类     命名空间System.IO

  对包含文件或目录路径信息的 String 实例执行操作。 这些操作是以跨平台的方式执行的

  返回指定路径字符串的文件名和扩展名。 public static string GetFileName(  string path )

  返回不具有扩展名的指定路径字符串的文件名。 public static string GetFileNameWithoutExtension(  string path )

  4:程序如下:

  这个程序如果你不输入文件的名字的话,会把应用程序当前目录下object/的所有文件都会转换成xml文件,如果你输入相应的execl文件名字,则只会转换你输入的execl文件(可以输入多个)

  我的目录结构如下::

  

 using System;
using System.IO;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Excel;
using System.Data;
using System.Xml; namespace ClientObjectTransform
{
class Program
{
static void Main(string[] args)
{
string str;
Console.WriteLine("请输入Excel文件名字(可输入1个,多个,也可以不输入)::");
str = Console.ReadLine();
args = str.Split(' ');
if ( args.Length >= )
{
Console.WriteLine("你输入的文件名字为::");
for (int i = ; i < args.Length; i++)
{
Console.WriteLine(string.Format("{0}::{1}", i + , args[i]));
}
}
LoadExcelData(args);
} static void LoadExcelData(string[] strFileNames)
{
//获取当前应用程序目录下的所有文件名
string[] strFiels = Directory.GetFiles(Directory.GetCurrentDirectory() + "/object/", "*.xls*", SearchOption.TopDirectoryOnly); if ( strFileNames.Length >= )
{ foreach (string strName in strFileNames)
{
string str = Directory.GetCurrentDirectory() + "/object/"+strName + ".xlsx";
//Console.Write("str file:{0}", str);
if (strFiels.Contains(str))
{
LoadOneFile(str);
}
}
} else
{
foreach (string strPath in strFiels)
{
if ( strPath.Length > )
{
LoadOneFile(strPath);
}
}
}
Console.Write("按任意键退出...");
Console.ReadKey(true);
} static void LoadOneFile(string strPath)
{
FileInfo fileinfo = new FileInfo(strPath);
FileStream filestream; if (fileinfo != null)
{
filestream = fileinfo.Open(FileMode.Open, FileAccess.Read); //FileAccess::指定对文件的读取和写入访问。
IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(filestream);
filestream.Close(); // 第二行是key 第三行是类型,所以从第四行开始读就可以 DataSet result = excelReader.AsDataSet();
DataTable datatable = result.Tables[]; int columns = datatable.Columns.Count; //execl列
int rows = datatable.Rows.Count; //execl行 XmlDocument xmlDoc = new XmlDocument();
XmlNode rootNode = xmlDoc.CreateElement("object"); //假如根元素 string filename = Path.GetFileNameWithoutExtension(strPath); for (int i = ; i < rows; i++)
{
XmlNode objectNode = xmlDoc.CreateElement(filename);
for (int j = ; j < columns; j++)
{
string val = datatable.Rows[i][j].ToString();
bool bErrorData = (i == || i == || j == ) && val.Length == ;
if (bErrorData)
{
Console.Write("file:{0} key or type is null", filename);
continue;
} string nodeName = datatable.Rows[][j].ToString();
if (nodeName.Length == )
{
continue;
} XmlNode objectChildNode = xmlDoc.CreateElement(nodeName); XmlAttribute valAttr = xmlDoc.CreateAttribute("value"); //属性
valAttr.Value = val;
objectChildNode.Attributes.Append(valAttr); XmlAttribute typeAttr = xmlDoc.CreateAttribute("type");
typeAttr.Value = datatable.Rows[][j].ToString();
objectChildNode.Attributes.Append(typeAttr); objectNode.AppendChild(objectChildNode);
} rootNode.AppendChild(objectNode);
} excelReader.Close(); xmlDoc.AppendChild(rootNode); xmlDoc.Save(Directory.GetCurrentDirectory() + "/clientobject/" + filename + ".xml"); //保存转换好的xml文件到指定目录
}
}
}
}

程序运行的结果

这样就会得到对应的xml文件了.

C# Execl表格文件转xml文件的更多相关文章

  1. web端自动化——Python读取txt文件、csv文件、xml文件

    1.读取txt文件 txt文件是我们经常操作的文件类型,Python提供了以下几种读取txt文件的方式. 1)read(): 读取整个文件. 2)readline(): 读取一行数据. 3)readl ...

  2. LINQ to XML 从逗号分隔值 (CSV) 文件生成 XML 文件

    参考:http://msdn.microsoft.com/zh-cn/library/bb387090.aspx 本示例演示如何使用 语言集成查询 (LINQ) 和 LINQ to XML 从逗号分隔 ...

  3. schema文件及XML文件的DOM和Sax解析

    schema文件 <?xml version="1.0" encoding="UTF-8"?> <schema xmlns="htt ...

  4. 关于跨域策略文件crossdomain.xml文件

    下载flexpaper源码修改后做成swf阅读器,要加入待阅读的swf文件,可以在flex里调用js的方法来获取swf文件的路径的方法,在js只专注获取路径就行,等着flex来调用:但这里会遇到一个问 ...

  5. Java文件操作①——XML文件的读取

    一.邂逅XML 文件种类是丰富多彩的,XML作为众多文件类型的一种,经常被用于数据存储和传输.所以XML在现今应用程序中是非常流行的.本文主要讲Java解析和生成XML.用于不同平台.不同设备间的数据 ...

  6. spring配置中,properties文件以及xml文件配置问题

    spring方便我们的项目快速搭建,功能强大,自然也会是体系复杂! 这里说下配置文件properties管理的问题. 一些不涉及到代码逻辑,仅仅只是配置数据,可以放在xxxx.properties文件 ...

  7. C#程序:如何创建xml文件以及xml文件的增、删、改、查

    其实今天的这篇博文 ,是对请几天发表的博文的一个总结,只是想把xml文件的增删改查结合起来,这样更容易让初学的朋友理解,废话也不多说了,开始吧! 下面是我把我在vs环境下写的代码ctrl+V然后ctr ...

  8. json串转化成xml文件、xml文件转换成json串

    1.json串转化成xml文件 p=[{"name":"tom","age":30,"sex":"男" ...

  9. 设置Eclipse的类文件和xml文件代码自动补全

    原文:https://blog.csdn.net/erlian1992/article/details/53706736 我们在平常编写代码的时候,不会记住大多数的类和文件的属性,方法等等,这就需要我 ...

随机推荐

  1. 前端touch事件方向的判断

    移动端touch事件判断滑屏手势的方向 方法一 当开始一个touchstart事件的时候,获取此刻手指的横坐标startX和纵坐标startY: 当触发touchmove事件时,在获取此时手指的横坐标 ...

  2. vue技术解析二之组件通信

    --------------------------动画效果----------------------------------- <transition name="router-f ...

  3. MYSQL数据库学习十七 日志管理

    17.1 MySQL软件所支持的日志 MySQL所支持的日志文件里,除了二进制日志文件外,其他日志文件都是文本文件.默认情况下,MySQL只会启动错误日志文件,其他日志文件则需要手动启动. 二进制日志 ...

  4. JVM学习六:JVM之类加载器之双亲委派机制

    前面我们知道类加载有系统自带的3种加载器,也有自定义的加载器,那么这些加载器之间的关系是什么,已经在加载类的时候,谁去加载呢?这节,我们将进行讲解. 一.双亲委派机制 JVM的ClassLoader采 ...

  5. MyBatis-plus 代码生成器

    1.添加pom文件依赖 <!-- Mybatis-Plus 自动生成实体类--> <dependency> <groupId>com.baomidou</gr ...

  6. java设计模式------建造者模式

    建造者模式(Builder),将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 类图 描述 Builder:定义一个建造者抽象类,以规范产品对象的各个组成部分的建造.这个接口 ...

  7. js和jquery判断checkbox是否被选中

    js判断: if(document.getElementById("checkboxID").checked){ alert("checkbox is checked&q ...

  8. Vue项目使用CDN优化首屏加载

    前言 作为一个网站应用,加载速度是非常重要的.加载速度,一个是程序的合理安排,如以组件按需加载,一个是js.css等资源的异步加载. 在Vue项目中,引入到工程中的所有js.css文件,编译时都会被打 ...

  9. beta冲刺用户测评-咸鱼

    测评人:庄加鑫-咸鱼 测评结果  一.使用体验数据加载响应很快!页面切换丝滑流畅!UI有点偏暗,有些字被覆盖了.页面布局过于居中,两侧空白范围较大.总体功能完善.二.登录.注册.忘记密码界面管理员登录 ...

  10. beta冲刺4-咸鱼

    昨天的问题: 我的社团数据库表项的处理,代码修改后结果无法显示. 帖子内容无法显示出来. 首页图像未替换 登陆整合没有完成 今天的完成: 服务器部署成功 页面背景修改.(已上传,未确认实装.) 任务截 ...