VB.NET导出Excel 轻松实现Excel的服务器与客户端交换 服务器不安装Office
说来VB.Net这个也是之前的一个项目中用到的。今天拿来总结下用途,项目需求,不让在服务器安装Office办公软件。这个也是煞费了一顿. 主要的思路就是 在导出的时候,利用DataTable做中间变量导出
下边这个是使用时候的代码 getData()方法是我获取的DataTable "defaultPickUpLocation"
是表的名字
'導出Excel
Protected Sub btnExport_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnExport.Click
Dim dt As DataTable = getData()
GridViewHelper.ExportToExcel(dt, "defaultPickUpLocation_")
End Sub
下边接下来是导出的方法 GridView 是自定义的类文件
Shared Sub ExportToExcel(ByVal dataTable As Data.DataTable, ByVal fileName As String)
For Each dataRow As DataRow In dataTable.Rows
For i As Integer = 0 To dataRow.ItemArray.Count - 1
If Not IsDBNull(dataRow.Item(i)) Then
dataRow.Item(i) = removeHTMLTagat(CType(dataRow.Item(i), String))
End If
Next
Next
Export2Excel(dataTable, fileName)
因为数据库中总有一些是Table的字节 现在要删除
Private Shared Function removeHTMLTagat(ByVal HTML As String) As String
Dim Codehtml() As KeyValuePair(Of String, String) = New KeyValuePair(Of String, String)() {
New KeyValuePair(Of String, String)("<", "<"),
New KeyValuePair(Of String, String)(">", ">"),
New KeyValuePair(Of String, String)(" ", " ")
}
For Each keyValuePair As KeyValuePair(Of String, String) In Codehtml
Dim regex As New Regex(keyValuePair.Key)
HTML = regex.Replace(HTML, keyValuePair.Value)
Next
Dim aryReg() As String = New String() {
"<[^>]*>"}
For Each pattern As String In aryReg
Dim regex As New Regex(pattern)
HTML = regex.Replace(HTML, "")
Next
Return HTML
End Function
还有Export2Excel的具体导出Excel的方法
Private Shared Sub Export2Excel(ByVal _dataTable As DataTable, ByVal _filename As String)
Dim fileName = String.Format("{0}{1}.xls", _filename, DateTime.Now.ToString("yyMMddHHmmssffff"))
Dim sNewFullFile = String.Format("{0}Downfiles/{1}", HttpContext.Current.Request.PhysicalApplicationPath, fileName)
File.Copy(String.Format("{0}format_files/{1}format.xls", HttpContext.Current.Request.PhysicalApplicationPath, _filename), sNewFullFile)
Dim strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=True;Data Source=" + sNewFullFile + ";Extended Properties='Excel 8.0;HDR=Yes;IMEX=0'"
Dim conn = New OleDbConnection(strConn)
Dim cmd As OleDbCommand = Nothing
Dim bRet = False
conn.Open()
Dim insertDataStr = "INSERT INTO [Sheet1$] ("
Dim insertValueStr = "values("
For i As Integer = 0 To _dataTable.Columns.Count - 1
insertDataStr = String.Format("{0} [{1}],", insertDataStr, _dataTable.Columns(i).ColumnName)
insertValueStr = String.Format("{0}{1},", insertValueStr, "?")
Next
insertValueStr = String.Format("{0})", insertValueStr.Trim(","c))
insertDataStr = String.Format("{0}) {1}", insertDataStr.Trim(","c), insertValueStr) cmd = New OleDbCommand(insertDataStr, conn)
For i As Integer = 0 To _dataTable.Columns.Count - 1
cmd.Parameters.Add(i.ToString(), OleDbType.LongVarChar)
Next
For Each row As DataRow In _dataTable.Rows
For i As Integer = 0 To _dataTable.Columns.Count - 1
Dim value = row(_dataTable.Columns(i).ColumnName).ToString()
If value.Length > 100 Then
value = String.Format("{0}……", value.Substring(0, 100))
End If cmd.Parameters(i).Value = value
Next
cmd.ExecuteNonQuery()
Next
bRet = True cmd.Dispose()
conn.Dispose()
If bRet Then
HttpContext.Current.Response.Redirect(String.Format("Downfiles/{0}", fileName))
End If End Sub
现在就写了这个文件,等把导入再写。如有问题 请回复 祝君成功。
VB.NET导出Excel 轻松实现Excel的服务器与客户端交换 服务器不安装Office的更多相关文章
- Java导出带格式的Excel数据到Word表格
前言 在Word中创建报告时,我们经常会遇到这样的情况:我们需要将数据从Excel中复制和粘贴到Word中,这样读者就可以直接在Word中浏览数据,而不用打开Excel文档.在本文中,您将学习如何使用 ...
- 如何使用NPOI 导出到excel和导入excel到数据库
近期一直在做如何将数据库的数据导出到excel和导入excel到数据库. 首先进入官网进行下载NPOI插件(http://npoi.codeplex.com/). 我用的NPOI1.2.5稳定版. 使 ...
- c# 高效率导出多维表头excel
[DllImport("User32.dll", CharSet = CharSet.Auto)] public static extern int GetWindowThread ...
- C#导出Excel,并且设置Excel单元格格式,合并单元格.
注:要添加COM组件 Microsoft Excel 11.0 Object Library 引用. 具体代码如下: using System; using System.Collections.G ...
- thinkphp用phpexcel读取excel,并修改列中的值,再导出excel,带往excel里写入图片
<?php class GetpriceAction extends AdministratorAction { // 文件保存路径 protected $savepath; // 允许上传的文 ...
- ASP.NET导出Excel(利用NPOI和EPPlus库,无需安装Office)
网上提供了很多Asp.net中操作Excel的方法,其中大部分是调用微软的Office组件,下面提供三个无须安装Office即可从Asp.net输出Excel的方法. 1 简单方法 //下面代码输出的 ...
- 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法
-----转载:http://blog.csdn.net/sgear/article/details/7663502 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格 ...
- PHP导出MySQL数据到Excel文件
PHP导出MySQL数据到Excel文件 转载 常会碰到需要从数据库中导出数据到Excel文件,用一些开源的类库,比如PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存 ...
- ASP.NET导出EXCEl方法使用COM.EXCEL不使用EXCEl对象
第一种:导出gridVIEW中的数据,用hansTABLE做离线表,将数据库中指定表中的所有数据按GRIDVIEW中绑定的ID导出 只能导出数据不能去操作相应的EXCEl表格,不能对EXCEL中的数据 ...
随机推荐
- HTML5--浏览器全屏操作、退出全屏、是否全屏
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- servlet--context域
ServletContext(重要) 一个项目只有一个ServletContext对象! 我们可以在N多个Servlet中来获取这个唯一的对象,使用它可以给多个Servlet传递数据! 与天地同寿!! ...
- seaborn教程4——分类数据可视化
https://segmentfault.com/a/1190000015310299 Seaborn学习大纲 seaborn的学习内容主要包含以下几个部分: 风格管理 绘图风格设置 颜色风格设置 绘 ...
- CSV的规范与使用
CSV可以通过Excel打开,数据格式比较小,通过记事本打开一个CSV文件, 便知道在csv里面,每一个单元格的数据都是通过逗号来分割的.所以在csv里面切记:单元格数据不要出现逗号 格式: 第一行: ...
- iBatis——自动生成DAO层接口提供操作函数(详解)
iBatis——自动生成DAO层接口提供操作函数(详解) 在使用iBatis进行持久层管理时,发现在使用DAO层的updateByPrimaryKey.updateByPrimaryKeySelect ...
- springcloud费话之Eureka接口调用(feign)
目录: springcloud费话之Eureka基础 springcloud费话之Eureka集群 springcloud费话之Eureka服务访问(restTemplate) springcloud ...
- c#模板化生成接口
最近打算做这样一个事情,一个桌面系统项目既可以一体化部署,作为一个软件一个进程部署,也可以把业务服务化部署. 那一般意味着我们要完全写2套东西,一套是直接UI调用业务,一套是Ui调用RPC.这样比较多 ...
- 廖雪峰Python电子书总结
函数 1.注意:函数的默认参数必须指向不可变对象 未修改前: def add_end(L=[]): L.append('END') return L 存在的问题:如果连续调用多次,会出现多个 'END ...
- 各种条码的校验码算法(EAN13,COD128,GTIN,UCC等)
校验码是由编码方案决定的,所以在代码中是否使用校验码和条码基本无关,但商品条码除外.今天给大家介绍几种校验码的计算方法. 一.商品条码: 商品条码中需要计算校验码的有:EAN-8(8位),EAN-13 ...
- myeclipse2014删除antlr-2.7.2.jar--解决struts和hibernate包冲突
方式一: 要求眼疾手快,在workspace下的D:\myeclipse2014workspace\.metadata\.me_tcat7\webapps\工程名\WEB-INF\lib中将antlr ...