指定路径批量将xls转换成csv
PS : 用到spire库,.net控制台应用程序
其实本来没打算写这个工具的,只是最近需要用到,手头上正好没有这样的工具,那么怎么办,写呗!
其实说白了就是省事,策划想怎么玩,把表把工具丢给他,省得策划两分钟来拍一次你的后背,哈哈哈!
下面附上代码,注释得很清楚,我挑需要注意的说一下就好...
1 using System;
2 using System.Collections.Generic;
3 using System.Linq;
4 using System.Text;
5 using System.Threading.Tasks;
6 using System.IO;
7 using Spire.Xls;
8 using Spire.Xls.Collections;
9
10 namespace ExcelTools
11 {
12 class Program
13 {
14 /// <summary>
15 /// 程序入口
16 /// </summary>
17 /// <param name="args"></param>
18 static void Main(string[] args)
19 {
20 try
21 {
22 //exe同级目录下的pathconfig配置文件
23 string dataPath = Directory.GetCurrentDirectory() + @"\PathConfig.txt";
24 //用流方式读取配置文件
25 StreamReader streamReader = new StreamReader(dataPath);
26 //因为只设置了一行,用逗号隔开,所以只读一行
27 string msg = streamReader.ReadLine();
28 //将两个路径分开
29 string[] getPath = msg.Split(',');
30 //第一个是输入路径
31 string inPath = getPath[0];
32 //第二是输出路径
33 string outPath = getPath[1];
34 //读完后关闭加载器
35 streamReader.Close();
36 Console.WriteLine("文件路径:" + inPath);
37 Console.WriteLine("转换存放路径:" + outPath);
38 List<string> xlsPathList = new List<string>();//用来接指定文件路径
39 List<string> tmpList = new List<string>();//递归过渡缓存
40 //拿到指定xls路径列表
41 xlsPathList = GetAllXls(inPath, tmpList);
42 //遍历转换
43 for (int i = 0; i < xlsPathList.Count; i++)
44 {
45 Console.WriteLine(string.Format("开始转换{0}...", xlsPathList[i]));
46 StartConver(xlsPathList[i], outPath);
47 }
48 Console.WriteLine("全部转换已经完成!");
49 Console.ReadLine();
50 Console.Clear();
51 }
52 catch (Exception e)
53 {
54 Console.WriteLine(e.Message);
55 Console.ReadLine();
56 return;
57 }
58 }
59 /// <summary>
60 /// 开始转换
61 /// </summary>
62 /// <param name="inPath">指定文件路径</param>
63 /// <param name="outPath">转换完成输出路径</param>
64 static void StartConver(string inPath, string outPath)
65 {
66 try
67 {
68 Workbook work = new Workbook();//实例化一个对象
69 work.LoadFromFile(inPath);//调用对象方法,加载指定文件
70 WorksheetsCollection sheetArr = work.Worksheets;//拿到这个xls所有的sheet
71 //遍历所有的sheet
72 for (int i = 0; i < sheetArr.Count; i++)
73 {
74 string printPath = outPath + sheetArr[i].Name + ".csv";//输出路径指定命名
75 sheetArr[i].SaveToFile(printPath, ",", Encoding.UTF8);//保存转换完成的文件到路径下,设置编码格式
76 Console.WriteLine(string.Format("转换完成{0}", sheetArr[i].Name));
77 }
78 }
79 catch (Exception e)
80 {
81 Console.WriteLine(e.Message);
82 Console.ReadLine();
83 }
84 }
85 /// <summary>
86 /// 获取指定路径下所有指定类型的文件路径
87 /// </summary>
88 /// <param name="inPath">指定文件夹路径</param>
89 /// <param name="fileList">路径列表</param>
90 /// <returns></returns>
91 static List<string> GetAllXls(string inPath, List<string> fileList)
92 {
93 string fileName;
94 DirectoryInfo dir = new DirectoryInfo(inPath);//实例化路径对象
95 FileInfo[] fil = dir.GetFiles();//从对象上拿到所有的文件列表
96 DirectoryInfo[] dii = dir.GetDirectories();//得到当前路径的所有子目录
97 //遍历文件列表,拿到指定类型文件
98 foreach (FileInfo f in fil)
99 {
100 fileName = f.FullName;
101 if (fileName.EndsWith("xls"))
102 {
103 fileList.Add(fileName);
104 }
105 }
106 //这里是递归,用来拿到子目录里面还有文件里面的指定文件
107 foreach (DirectoryInfo d in dii)
108 {
109 GetAllXls(d.FullName, fileList);
110 }
111 return fileList;
112 }
113 }
114 }
(1)路劲问题
你要转文件,肯定得有一个起点一个终点,不推荐在代码里面写死路径,这样可以保证通用性,我写得比较懒,直接把两个路径写成配置文件,间接明了
这里需要注意的是,stream这些文件流在使用完成后必须关闭;Directory.GetCurrentDirectory() 这个就是你的exe所在文件夹路径

(2)用递归去获取xls文件是为了防止有些表分类很细很细,这里也是写死了是xls

(3)到这里转换就需要用到spire库,主要的转换功能就在它,就在它,就在它!重要的事情说三遍


(3)最后就可以运行了,我是直接转到unity里读取,当然你也可以再继续转成json文件放到unity里,其实都是一样的
指定路径批量将xls转换成csv的更多相关文章
- 用 unoconv 将 xls 转换成 csv
在 Linux 下,用 unoconv 将 xls 转换成 csv. unoconv -f csv -v input.xlsx
- 【游戏开发】Excel表格批量转换成CSV的小工具
一.前言 在工作的过程中,我们有时可能会面临将Excel表格转换成CSV格式文件的需求.这尤其在游戏开发中体现的最为明显,策划的数据文档大多是一些Excel表格,且不说这些表格在游戏中读取的速度,但就 ...
- 将DataTable转换成CSV文件
DataTable用于在.net项目中,用于缓存数据,DataTable表示内存中数据的一个表.CSV文件最早用在简单的数据库里,由于其格式简单,并具备很强的开放性,所以起初被扫图家用作自己图集的标记 ...
- 转换成CSV文件、Word、Excel、PDF等的方法--读取CSV文件的方法
1. 转换成CSV文件: http://www.dotnetgallery.com/lab/resource93-Export-to-CSV-file-from-Data-Table-in-Aspne ...
- 批量将网页转换成图片或PDF文档技巧分享
工作中我们有时要将一些批量的网页转换成图片或者PDF文档格式,尽管多数浏览器具有滚动截屏或者打印输出PDF文档功能.可是假设有几十上百张网页须要处理,那也是要人命的.所以我一直想找一款可以批量处理该工 ...
- 使用VBA批量转换Excel格式,由.xls转换成.xlsx
问题分析: Excel2007以前的格式是.xls,之后的格式是.xlsx.打开单独的一个Excel文档,使用“另存为”功能,可以很轻松的转换格式.但是面对几百个Excel表这样就太累了,搜索很久,也 ...
- Python: 把txt文件转换成csv
最近在项目上需要批量把txt文件转成成csv文件格式,以前是手动打开excel文件,然后导入txt来生产csv文件,由于这已经变成每周需要做的事情,决定用python自动化脚本来实现,思路: 读取文件 ...
- 将日期转换为指定的格式:比如转换成 年月日时分秒 这种格式:yyyy-MM-dd hh:mm:ss 或者 yyyy-MM-dd。总结下。
可以为Date原型添加如下的方法: Date.prototype.format = function(fmt) { var o = { "M+" : this.getMonth() ...
- 怎样把txt文档转换成csv文件?
其实csv就是逗号隔开的一行一行的数据, 如果每行数据中都是用逗号分隔的,直接把文件后缀txt改成csv就行了. 用python搞定: import numpy as np import pandas ...
随机推荐
- 蓝松SDK支持以下的AE特性
蓝松短视频SDK 支持Ae模板, 您可以在PC端用AE设计好模板,然后导入到SDK中, 蓝松SDK支持一下的AE特性:1, Ae中的图片图层,任意多个图片图层, 每个图片的移动旋转缩放透明,锚点,蒙版 ...
- Java基础学习笔记(六) - 数据结构和集合
一.认识数据结构 1.数据结构有什么用? 合理的使用数据结构,可以更方便的查找存储数据. 2.常见的数据结构 数据存储常用结构有:栈.队列.数组.链表和红黑树. 栈:堆栈(stack),它是运算受限的 ...
- C#中winform中panel重叠无法显示问题
C#中winform中panel重叠无法显示问题: 最近开发一个项目有个需求是需要多个模式来回切换的,本来考虑使用多个窗口来实现这个功能,但是这样做浪费资源,而且工作量大,所以想到使用panel控件来 ...
- CSDN VIP如何添加引流自定义栏目
几个月前我也开始在csdn上开了博客,一来给自己加几个少的可怜的流量,再者,让公众号的原创文章获得更多的曝光,让有需要的同学看到. 写过csdn博客的同学都知道,默认只有打赏c币功能:也没有专门广告位 ...
- python程序调用C/C++代码
这篇用来记录在些模拟Canoe生成CAN数据桢工具时遇到的问题, 生成CAN数据桢,主要分为两个关注点: 1.如何从can信号名获取到can信号的ID长度以及信号的起始位,并将信号值按照一定的规则填写 ...
- sudo 提示 'xxx is not in the sudoers file.This incident will be reported.的解决方法'
在使用 Linux 的过程中,有时候需要临时获取 root 权限来执行命令时,一般通过在命令前添加 sudo 来解决. 但是第一次使用 sudo 时,有可能会得到这样一个错误提示 xxx is not ...
- GLSL 参考GIMP源码实现色彩平衡调节
色彩平衡 修图工具中的色彩平衡一般用来根据亮度等级调整图片中颜色的偏色,调整偏色涉及到加色原理和减色原理 其实我们通过三原色加色原理的图片就可以知道,红色的对比色是青色,蓝色的对比色是黄色,绿色的对比 ...
- 关于Qt画点及计算机专业基础课程介绍
在计算机图形图像学中,开始都是先画点,我曾经在汇编上tc2.0上画点,后来是MFC,VB,Qt,Python,我觉得对于计算机专业的选择QT的原因是它是个C系的功能强大庞大的库,可以少写很多代码,但是 ...
- powershell加载EXE进内存运行
当实战中我们想在目标上运行一些相当复杂的功能,这些功能常是 EXE 文件的一部分.我不想直接在目标上放置一个二进制文件,因为这样可能会触发反病毒机制.一个很好的思路就是将二进制文件嵌入到 Powers ...
- [Luogu2422]良好的感觉
题目描述 kkk做了一个人体感觉分析器.每一天,人都有一个感受值Ai,Ai越大,表示人感觉越舒适.在一段时间[i, j]内,人的舒适程度定义为[i, j]中最不舒服的那一天的感受值 * [i, j]中 ...