VB.net使用Microsoft.Office.Interop.Excel对Excel进行简单的读取和写入
环境:Visual Stadio 2017 .NET Framework 4.6.1
1.直接进入正题,新建一个控制台程序,右键引用-管理Nuget程序包,搜索Microsoft.Office.Interop.Excel并安装至Packages

2.打开Module1.vb,在主函数中调用dll内的类和方法,主要功能是读取excel中第二行开始每行的单元格的内容,并打印到控制台。
excel内容如下图

代码如下
Sub Main()
Dim ExlApp As Microsoft.Office.Interop.Excel.Application
Dim ExlBook As Microsoft.Office.Interop.Excel.Workbook
Dim ExlSheet As Microsoft.Office.Interop.Excel.Worksheet
Dim strFilePath As String = "D:/2020.12考勤.xlsx"
ExlApp = New Microsoft.Office.Interop.Excel.Application
If Not FileIO.FileSystem.FileExists(strFilePath) Then
Console.WriteLine("找不到文件。")
Else
ExlBook = ExlApp.Workbooks.Open(strFilePath)
ExlSheet = ExlBook.Worksheets("Sheet1")
Dim row As Integer
row = ExlSheet.UsedRange.Rows.Count
Dim a, b, c, d, e, f, g
For i = 2 To row
a = ExlSheet.Cells(i, 1).value
b = ExlSheet.Cells(i, 2).value
c = ExlSheet.Cells(i, 3).value
d = ExlSheet.Range($"D{i}").Text
e = ExlSheet.Range($"E{i}").Text
f = ExlSheet.Range($"F{i}").Text
g = ExlSheet.Cells(i, 7).value
If Not a = Nothing Then
Console.WriteLine($"工号:{a} 姓名:{b} 部门:{c} 日期:{d} 上班时间:{e} 下班时间:{f} 出勤状况:{g}")
End If
Next
ExlBook.Close()
ExlApp.Quit()
End If
Console.Read()
End Sub
其中
ExlApp为Application对象,即Excel本身;
ExlBook为workbooks对象集,指Excel的工作簿文件;
ExlSheet为worksheets对象集,表示的是Excel的一个工作表;
Cells和Range对象,指向Excel工作表中的单元格(Range也可用于指代单元区域:某一单元格、某一单元格区域、某一行、某一列、或者是多个连续或非连续的区域组成的区域)。
另外,Excel中D列、E列和F列为时间格式,用Cell(i,j).value的方法会出现一些问题,稍后解释,此处用Range(列名).Text替代之。
先来看看运行效果,结果如下图:

3.插入数据功能
代码如下
Private Sub InsertRow()
Dim myWorkExl As Microsoft.Office.Interop.Excel.Application
Dim ExlBook As Microsoft.Office.Interop.Excel.Workbook
Dim ExlSheet As Microsoft.Office.Interop.Excel.Worksheet
myWorkExl = CreateObject("Excel.application")
myWorkExl.Visible = True
ExlBook = myWorkExl.Workbooks().Open("D:/myWorkExl.xlsx")
ExlSheet = ExlBook.Worksheets(1)
ExlSheet.Activate()
myWorkExl.Cells(1, 1) = 1
myWorkExl.Cells(1, 2) = 2
myWorkExl.Cells(1, 3) = "3"
myWorkExl.Cells(1, 4) = "4"
myWorkExl.Range("E1").Value = Format(Now, "HH:mm:ss")
ExlBook.Save()
ExlBook.Close()
myWorkExl.Quit()
End Sub
效果如下图

4.Cell和Range,前面提到的如果用Cell()方法读取特殊格式的值,比如时间会显示成小数,这不是我们所要的。这里有两种解决办法
- 第一种是用Range().Text代替
- 第二种,从excel中读取到的小数其实也能转化为时间,需要一些操作,以上面的9:00:00为例,从excel中读取到的值为0.375
Private Sub Text()
Dim temp1 As Double
temp1 = 0.375
Dim temp2 As Double
temp2 = temp1 * 86400
Dim temp3
temp3 = Format(DateAdd("s", CDec(temp2), "00:00:00"), "HH:mm:ss")
Console.WriteLine($"原始数据为:{temp1}")
Console.WriteLine($"换算后为:{temp2}")
Console.WriteLine($"最终结果为:{temp3}")
Console.Read()
End Sub
输出结果如下图

VB.net使用Microsoft.Office.Interop.Excel对Excel进行简单的读取和写入的更多相关文章
- C# Microsoft.Office.Interop.Owc11 导出excel文件
C# Microsoft.Office.Interop.Owc11 导出excel文件 1.新建项SupremeWindowsForms窗体应用项目(项目平台设置称X86) 注意:因为大多数第三方写的 ...
- Microsoft.Office.Interop.Excel的用法以及利用Microsoft.Office.Interop.Excel将web页面转成PDF
1.常见用法 using Microsoft.Office.Interop.Excel; 1)新建一个Excel ApplicationClass ExcelApp = New A ...
- 引用Microsoft.Office.Interop.Excel出现的问题
引用Microsoft.Office.Interop.Excel出现的问题 转自:http://www.hccar.com/Content,2008,6,11,75.aspx,作者:方继祥 操作背 ...
- Microsoft.Office.Interop.Excel操作Excel文件时出现的问题及解决方案
问题描述: Microsoft.Office.Interop.Excel.Worksheet 打不开文件 Microsoft Office Excel 不能访问文件"a.xls". ...
- Microsoft.Office.Interop.Excel 程序集引用 ,Microsoft.Office.Interop.Excel.ApplicationClass 无法嵌入互操作类型
using Microsoft.Office.Interop.Excel 添加程序集引用 方法:在引用--程序集--扩展中,添加引用Microsoft.Office.Interop.Excel,此 ...
- 利用Microsoft.Office.Interop.Excel 将web页面转成PDF
网上有很多将Web页面转成PDF的方法,还有许多收费的第三方插件.其实利用Office 自带的将EXCEL发布成PDF的功能就可以实现,如果你的需求没有多复杂,可以采用笔者的方法. 首先将web页面h ...
- Microsoft.Office.Interop.Excel, Version=12.0.0.0版本高于引用的程序集(已解决)
Microsoft.Office.Interop.Excel, Version=12.0.0.0版本高于引用的程序集(已解决) 论坛里的帮助:http://bbs.csdn.net/topics/39 ...
- 无法嵌入互操作类型“Microsoft.Office.Interop.Excel.ApplicationClass”。请改用适用的接口
解决 把Microsoft.Office.Interop.Excel.DLL的嵌入互操作类型改为ture就可以了
- 解决方法:未能加载文件或程序集“Microsoft.Office.Interop.Excel。。
.NET错误提示:未能加载文件或程序集“Microsoft.Office.Interop.Excel, Version=11.0.0.0, Culture=neutral, PublicKeyToke ...
随机推荐
- JavaScript 的Date构造函数太迷惑了。。。
1 new Date(2021,0,1,0,0,0,0) ===> Fri Jan 01 2021 00:00:00 GMT+0800 (中国标准时间) 2 new Date(2021,1,1, ...
- 关于根据数据反选checkbox
前两天完成了一个连接hbase数据库的mis系统,mis系统中经常需要修改功能,复选框.多选框等等的自动勾选,感觉很麻烦,在此记录一下修改功能checkbox自动选中. 例子: <div cla ...
- js手机端判断滑动还是点击
网上的代码杂七杂八, 我搞个简单明了的!! 你们直接复制粘贴, 手机上 电脑上 可以直接测试!!! 上图: 上代码: <!DOCTYPE html> <html lang=&q ...
- Python入门-程序结构扩展
deque双端队列 #双端队列,就是生产消费者模式,依赖collections模块 from collections import deque def main(): info = deque((&q ...
- 取地址与解引用 C指针浅析
C语言指针入门需要掌握的两个概念就是取地址&和解引用*,下面我们按例子来理解这两个符号的使用. int main() { int a = 0; int* pa = &a;//取地址操作 ...
- Python 图_系列之纵横对比 Bellman-Ford 和 Dijkstra 最短路径算法
1. 前言 因无向.无加权图的任意顶点之间的最短路径由顶点之间的边数决定,可以直接使用原始定义的广度优先搜索算法查找. 但是,无论是有向.还是无向,只要是加权图,最短路径长度的定义是:起点到终点之间所 ...
- 两数之和II_LeetCode_167_1099
LeetCode_167原题链接:https://leetcode-cn.com/problems/two-sum-ii-input-array-is-sorted/ LeetCode_1099原题链 ...
- Python 国家地震台网中心地震数据集完整分析、pyecharts、plotly,分析强震次数、震级分布、震级震源关系、发生位置、发生时段、最大震级、平均震级
注意,本篇内容根据我老师布置的数据分析作业展开.请勿抄袭,后果自负! 前情提要 编写这篇文章是为了记录自己是如何分析地震数据集,使用模块,克服一系列 \(bug\) 的过程.如果你是 \(python ...
- php进制转换
前端html页面代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- AcWing 158. 项链 (最小表示法)
项链 题源:https://www.acwing.com/problem/content/160/ 题目 原理:最小表示法 找字典序最小的字符串 循环移位,破环成链 (把原串复制一倍) memcpy ...