C# Microsoft.Office.Interop.Owc11 导出excel文件
C# Microsoft.Office.Interop.Owc11 导出excel文件
1、新建项SupremeWindowsForms窗体应用项目(项目平台设置称X86)
注意:因为大多数第三方写的COM控件,只支持32位的系统,因此在VS中找到引用控件所在的项目SupremeWindowsForms设置一下,SupremeWindowsForms项目--〉属性--〉生成--〉常规---〉目标平台---〉选择X86即可
否则会出现如下问题:
检索 COM 类工厂中 CLSID 为 {XXXX-XXXX-XXX-XXXXX-XXX} 的组件时失败,原因是出现以下错误: 80040154。
如以上问题出现,多半是因为COM控件未在目标机器上面注册造成的
解决方法:Resvr32 .net中引用控件的名称,如果注册成功,问题不在出现
但是如果是在x64位的系统中,即使控件注册成功,错误依照提示,是因为大多数第三方写的COM控件,只支持32位的系统,
在VS中找到引用控件所在的项目--〉属性--〉生成--〉常规---〉目标平台---〉选择X86即可解决
2、右键添加Microsoft.Office.Interop.Owc11.dll和OWC11.dll组件,下载地址https://download.csdn.net/download/LongtengGensSupreme/12037912
3、添加方法ExportExcel,
代码如下:
按钮事件方法:
private void btnTestchartPrint_Click(object sender, EventArgs e)
{
//测试 Microsoft.Office.Interop.Owc11 SpreadsheetClass
ExportExcel();
}
ExportExcel方法:
public void ExportExcel()
{
int colNum = ;
int rowNum = ;
SpreadsheetClass xlsheet = null;
try
{
xlsheet = new SpreadsheetClass();
}
catch
{
MessageBox.Show("测试Owc11 SpreadsheetClass出错", "测试Microsoft.Office.Interop.Owc11", MessageBoxButtons.OK);
try
{
FileInfo fi = new FileInfo(Path.Combine(Application.StartupPath, "OWC11.dll"));
if (fi.Exists)
{
Process p = new Process();
p.StartInfo = new ProcessStartInfo("regsvr32", "\"" + fi.FullName + "\"");
p.StartInfo.UseShellExecute = false;
p.StartInfo.CreateNoWindow = true;
p.StartInfo.WindowStyle = ProcessWindowStyle.Hidden;
p.Start();
p.WaitForExit();
}
}
catch
{
}
xlsheet = new SpreadsheetClass();
}
//xlsheet.Sheets.Add(null, xlsheet.Sheets.Count, null, null);
//Worksheet ws = xlsheet.Sheets[0] as Worksheet;
//ws.Name = "hello";
//xlsheet.ActiveSheet.Name = "";
//合并单元格
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[, colNum]).set_MergeCells(true);
xlsheet.ActiveSheet.Cells[, ] = "测试Microsoft.Office.Interop.Owc11";
//字体加粗
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[, colNum]).Font.set_Bold(true);
//单元格文本水平居中对齐
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[, colNum]).set_HorizontalAlignment(XlHAlign.xlHAlignCenter);
//设置字体大小
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[, colNum]).Font.set_Size();
//设置列宽
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[, ]).set_ColumnWidth();
//画边框线
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[rowNum, ]).Borders.set_LineStyle(XlLineStyle.xlDashDotDot);
int x = , y = ;
//写入数据 (这里可根据需要由ds生成)
for (int row = ; row < ; row++) //注意写入数据时,必须从第一行开始写excel里没有第"0"行
{
for (int i = ; i < ; i++)
{
xlsheet.ActiveSheet.Cells[row, i + ] = 123.456;
}
}
try
{
//将数字格式化为金额(要格式化的单元格内的值必须为数值型)
xlsheet.get_Range(xlsheet.Cells[, ], xlsheet.Cells[, ]).set_NumberFormat("¥#,##0.00");
xlsheet.Export(Path.Combine(Application.StartupPath, "testowc11.xls"), SheetExportActionEnum.ssExportActionNone, SheetExportFormat.ssExportXMLSpreadsheet);
MessageBox.Show("export ok");
Process.Start(Path.Combine(Application.StartupPath, "testowc11.xls"));
}
catch
{
MessageBox.Show("导出Owc11 SpreadsheetClass出错", "测试Microsoft.Office.Interop.Owc11", MessageBoxButtons.OK);
}
}
4、测试结果如下:

注意事项问题原文链接:https://blog.csdn.net/Fibona/article/details/5949180
C# Microsoft.Office.Interop.Owc11 导出excel文件的更多相关文章
- AxMicrosoft.Office.Interop.Owc11.AxSpreadsheet控件在C#中的引用
这几天要是用AxMicrosoft.Office.Interop.Owc11.AxSpreadsheet控件做查询,发现一系列问题,一点点记录下来吧,以备后查: 第一.相关属性:http://www. ...
- 使用Microsoft.Office.Interop.Excel.dll 文件来生成excel 文件
日常工作中经常需要将后台的数据导出成excel 格式,这里通过调用微软提供的类库来生成excel 文件. 具体是引用 了Microsoft.Office.Interop.Excel.dll 类库文件 ...
- Microsoft.Office.Interop.Excel操作Excel文件时出现的问题及解决方案
问题描述: Microsoft.Office.Interop.Excel.Worksheet 打不开文件 Microsoft Office Excel 不能访问文件"a.xls". ...
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
1.引用Microsoft.Office.Interop.Excel.dll 2.引用命名空间.使用别名 using System.Reflection; using Excel = Microsof ...
- C# 使用自带Microsoft.Office.Interop.Excel简单操作Excel文件
项目添加应用 Microsoft.Office.Interop.Excel.dll 文件 引用命名空间: using Excel = Microsoft.Office.Interop.Excel; 简 ...
- NPOI写Excel,Microsoft.Office.Interop.excel.dll 转换Excel为PDF
首先要引用NPOI动态库和Microsoft.Office.Interop.excel.dll (Microsoft.Office.Interop.excel.dll 下载链接 ,下载以后解压文件,把 ...
- 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 将web页面转成PDF
网上有很多将Web页面转成PDF的方法,还有许多收费的第三方插件.其实利用Office 自带的将EXCEL发布成PDF的功能就可以实现,如果你的需求没有多复杂,可以采用笔者的方法. 首先将web页面h ...
随机推荐
- 为 Linux 应用程序编写 DLL
插件和 DLL 通常是用来无须编写整个新应用程序而添加功能的极好方法. 在 Linux 中,插件和 DLL 是以动态库形式实现的. 电子商务顾问兼设计师 Allen Wilson 介绍了动态库,并且向 ...
- java 8大happen-before原则
1.单线程happen-before原则:在同一个线程中,书写在前面的操作happen-before后面的操作. 2.锁的happen-before原则:同一个锁的unlock操作happen-bef ...
- virt-install创建虚拟机并制作成模板
一.使用virt-install创建新的虚拟机 virt--template --ram --vcpu= --virt-type kvm --cdrom=/Data/kvm/iso/CentOS-.i ...
- Statefulset:部署有状态的多副本应用
10.1.什么是Statefulset StatefulSet是Kubernetes提供的管理有状态应用的负载管理控制器API. 特点: 1.具有固定的网络标记(主机名) 2.具有持久化 ...
- seaborn(2)---画分类图/分布图/回归图/矩阵图
二.分类图 1. 分类散点图 (1)散点图striplot(kind='strip') 方法1: seaborn.stripplot(x=None, y=None, hue=None, data=No ...
- httprunner学习12-hook 机制实现setup和teardown
前言 unittest框架里面有个非常好的概念:前置( setUp )和后置( tearDown )处理器,真正会用的人不多. HttpRunner 实际上也是从用的unittest框架,里面也有前置 ...
- html中的数据岛:利用DSO和javascript在html中动态加载和浏览xml数据
1.DSO也叫做数据源对象,IE 4.0引入了DSO,在IE 5.0对DSO技术进行很大的扩展.以往如果数据是通过SQL语言对数据库进行查询得到的结果,那么就把它们存放在ADO(ActiveX Dat ...
- scala简单的功能实现~weektwo
1.编写⼀个BankAccount类,假如deposit和withdraw⽅法,和⼀个只读的balance属性. //存款(deposit)和取款()函数 class BankAccount exte ...
- Ofbiz项目学习——阶段性小结——查询
一.组装参数的学习 首先是查询条件,对于查询条件,需要判断是否从前端传递空值?——怎么处理查询空值? 当然可以一个一个进行判断,但是这样代码会导致很多,可以统一处理,形成一个公共方法. 1. 单个处理 ...
- 【坑】js语法中一些小细节 不注意也出坑 随笔记下 留待后查
1.switch case内 区分数字 与 字符 ',bl; switch(+lv){ :bl = 1.7;break; :bl = 1.55;break; :bl = 1.4;break; ; } ...