C#/VB.NET Excel数据分列
C#/VB.NET Excel数据分列
有时候我们需要将保存在Excel单元格中的组合型数据拆分为多列(如将全名拆分为姓和名两列)以方便我们处理、记忆或保存。为了避免重复和大量的手动输入工作,Excel给我们提供了一个数据分列的功能。下面这幅图展示了如何在Excel中实现数据分列:
这篇文章将介绍如何使用C#和VB.NET编程的方式来实现Excel数据分列的功能。
步骤和代码:
第一步:创建一个新的Workbook类的对象,并加载Excel文档。
- Workbook book = new Workbook();
- book.LoadFromFile("测试.xlsx");
第二步:获取Excel文档中存放需要被拆分的数据的工作表,这里是第一个工作表。
- Worksheet sheet = book.Worksheets[];
第三步:按分隔符号将数据拆分为多列。
初始化一个字符串数组和一个字符串,遍历工作表中的指定行,按分隔符号(·)将数据为全名的那一列拆分为姓和名两列并将结果保存到字符串数组中,然后将数组的内容赋值给工作表的另两列。
- string[] splitText = null;
- string text = null;
- for (int i = ; i < sheet.LastRow; i++)
- {
- text = sheet.Range[i + , ].Text;
- splitText = text.Split('·');
- for (int j = ; j < splitText.Length; j++)
- {
- sheet.Range[i + , + j + ].Text = splitText[j];
- }
- }
第四步:保存文档。
- book.SaveToFile("输出.xlsx", ExcelVersion.Version2010);
运行代码,得到如下结果:
全部代码:
C#:
- using Spire.Xls;
- namespace Split_Column_Data_to_Several_Columns
- {
- class Program
- {
- static void Main(string[] args)
- {
- Workbook book = new Workbook();
- book.LoadFromFile("测试.xlsx");
- Worksheet sheet = book.Worksheets[];
- string[] splitText = null;
- string text = null;
- for (int i = ; i < sheet.LastRow; i++)
- {
- text = sheet.Range[i + , ].Text;
- splitText = text.Split('·');
- for (int j = ; j < splitText.Length; j++)
- {
- sheet.Range[i + , + j + ].Text = splitText[j];
- }
- }
- book.SaveToFile("输出.xlsx", ExcelVersion.Version2010);
- }
- }
- }
VB.NET:
- Imports Spire.Xls
- Namespace Split_Column_Data_to_Several_Columns
- Class Program
- Private Shared Sub Main(args As String())
- Dim book As New Workbook()
- book.LoadFromFile("测试.xlsx")
- Dim sheet As Worksheet = book.Worksheets()
- Dim splitText As String() = Nothing
- Dim text As String = Nothing
- For i As Integer = To sheet.LastRow -
- text = sheet.Range(i + , ).Text
- splitText = text.Split("·"C)
- For j As Integer = To splitText.Length -
- sheet.Range(i + , + j + ).Text = splitText(j)
- Next
- Next
- book.SaveToFile("输出.xlsx", ExcelVersion.Version2010)
- End Sub
- End Class
- End Namespace
(注意:这里我使用了一个免费的Excel组件)
C#/VB.NET Excel数据分列的更多相关文章
- VB操作EXCEL文件大全
Private Sub writeToExcel(strTmp1() As String, colTmp1 As Collection)'' Dim tmp1 Dim i1 As Integer, i ...
- EXCEL数据透视相关知识
要边看边总结要点:1.部门管理,标准化作业流程,控制生产经营过程,预知风险2.这一项内容,用一个工作薄三个SHEET表来完成.分类汇总表(可变,N个),源数据表(标准.规范.通用.简洁.正确),1.符 ...
- Oracle导入excel数据方法汇总[转]
摘要:在程序编制过程和数据汇总交换过程中,经常会碰到需要将其他人员在office办公环境下编制的文件数据内容导入oracle中的情况.目前程序开发者经常使用的方法有如下几种:1,使用oracle提供的 ...
- 在SQL中导入Excel数据时强制以文本类型导入
Excel不是关系型数据库,在导入到sql中时对于数值型,sql有时int型会处理成float,有时数字文本混排的列,sql会认为是数值型,导入的结果有的数据变成了null,但是用sql导出excel ...
- 向SQL2008R2导入Acess、excel数据
一:导入Access数据 1.在sql2008查询分析 器中输入如下查询语句能查出access中的数据 SELECT * FROM OpenDataSource( 'Microsoft.Jet.OLE ...
- java数据库导入excel数据
导入数据会将表格分为xls和xlsx两种格式,网上有很多案例 1.excel数据表中的数据不全,数据库中又是必填选项:---从sql语句入手:判断有无 来改变语句 //设置可有可无 字段 加一个必有字 ...
- 【转】 如何导入excel数据到数据库,并解决导入时间格式问题
在办公环境下,经常会用到处理excel数据,如果用写程序导入excel数据到数据库那就太麻烦了,涉及解析excel,还要各种格式问题,下面简单利用数据库本身支持的功能解决这类导入问题. 准备 创建表 ...
- Oracle导入excel数据快速方法
Oracle导入excel数据快速方法 使用PLSQL Developer工具,这个可是大名鼎鼎的Oracle DBA最常使用的工具. 在单个文件不大的情况下(少于100000行),并且目的 ...
- VB中Excel 2010的导入导出操作
VB中Excel 2010的导入导出操作 编写人:左丘文 2015-4-11 近来这已是第二篇在讨论VB的相关问题,今天在这里,我想与大家一起分享一下在VB中如何从Excel中导入数据和导出数据到Ex ...
随机推荐
- Asp.Net WebApi核心对象解析(下篇)
在接着写Asp.Net WebApi核心对象解析(下篇)之前,还是一如既往的扯扯淡,元旦刚过,整个人还是处于晕的状态,一大早就来处理系统BUG,简直是坑爹(好在没让我元旦赶过来该BUG),队友挖的坑, ...
- VisualVM通过jstatd方式远程监控远程主机
配置好权限文件 [root@test bin]# cd $JAVA_HOME/bin [root@test bin]# vim jstatd.all.policy grant codebase &qu ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
- ADO.NET对象的详解
1. Connection 类 和数据库交互,必须连接它.连接帮助指明数据库服务器.数据库名字.用户名.密码,和连接数据库所需要的其它参数.Connection对象会被Command对象使用,这样就能 ...
- OpenCASCADE Job - dimue
- 用html5的canvas和JavaScript创建一个绘图程序
本文将引导你使用canvas和JavaScript创建一个简单的绘图程序. 创建canvas元素 首先准备容器Canvas元素,接下来所有的事情都会在JavaScript里面. <canvas ...
- 初步认识TDD
TDD,测试驱动开发(Test Driven Development)是极限编程中倡导的程序开发方法,以其倡导先写测试程序,然后编码实现其功能得名.本文将对TDD有一个较为系统的认识. 基础属性 ...
- MVC通过路由实现URL重写
public static class WebApiConfig { public static void Register(HttpConfiguration config) { config.Ro ...
- Nested Loops join时显示no join predicate原因分析以及解决办法
本文出处:http://www.cnblogs.com/wy123/p/6238844.html 最近遇到一个存储过程在某些特殊的情况下,效率极其低效, 至于底下到什么程度我现在都没有一个确切的数据, ...
- WCF基础
初入职场,开始接触C#,开始接触WCF,那么从头开始学习吧,边学边补充. SOA Service-Oriented Architecture,面向服务架构,粗粒度.开放式.松耦合的服务结构,将应用程序 ...