C#下Excel的普通处理和报表设计
一、准备:想要操作Excel,先要在添加2个COM引用:
1、Microsoft Excel 14.0 Object Library (版本不同14.0也可能是12.0等)
2、Microsoft Office 14.0 Object Library
二、操作:
在Winform中,也须添加引用
using Microsoft.Office.Interop.Excel;
相应的,本类中原有的Datatable应改为System.Data.DataTable,否则将与Excel.Datatable冲突。
public partial class FrmExcelOp : Form
{
private Microsoft.Office.Interop.Excel.Application excel; //定义一个变量供全局使用
object missing = System.Reflection.Missing.Value; //定义一个参数变量供全局使用
}
private void ExportIvoice()
{
#region 变量定义
Workbook wkBookTmpInvoice = null;
Workbook wkBookTag = null;
#endregion try
{
#region Excel准备阶段
if (!Directory.Exists(tagTempFolder))
{
Directory.CreateDirectory(tagTempFolder);
}
if (!Directory.Exists(tagFolder))
{
Directory.CreateDirectory(tagFolder);
} if (excel2 == null)
{
//创建实例
excel2 = new Microsoft.Office.Interop.Excel.Application
{
UserControl = true
};
} if (excel2 == null)
{
MyMsg.Stop("无法打开EXCEL,请检查系统配置.");
return;
} //...其它操作
wkBookTmp = excel2.Application.Workbooks.Open(tmpFileFullName, missing, true, missing, missing, missing, missing, missing, missing, true, missing, missing, missing, missing, missing);
//可写/可编辑打开一个工作薄;
if (wkBookTmpInvoice == null)
{
MyMsg.Exclamation("开启文件失败,请检查!");
return;
}
for (int i = ; i <= wkBookTmp .Sheets.Count; i++)
{
Worksheet tmpSht = wkBookTmp .Sheets[i];
//添加上边线
tmpSht.Range["A13", "L13"].Borders.Item[XlBordersIndex.xlEdgeTop].LineStyle = XlLineStyle.xlContinuous;
//去除部分信息(给单元格赋值)
if (i < wkBookTmp .Sheets.Count) tmpSht.Range["A23", "A26"].Value2 = string.Empty;
}
//新建一个工作簿,后面可以保存为文件
wkBookTag = excel2.Workbooks.Add();
if (wkBookTag != null)
{
string tInvSheetName = "INV01";
//给工作簿中的表重命名
((Worksheet)wkBookTmp .Sheets[]).Name = tInvSheetName;
//将工作簿的表1拷贝一份插入到另一个工作簿的表1的前面
((Worksheet)wkBookTmp .Sheets[]).Copy(wkBookTag.Sheets[]); Worksheet tagSheet = wkBookTag.Sheets[tInvSheetName];
tagSheet.PageSetup.Zoom = false;
tagSheet.PageSetup.FitToPagesTall = false; //所有列调整为一页,与Excel的缩放设置对应,避免拆成2页打印
tagSheet.PageSetup.CenterHorizontally = true;//水平居中
tagSheet.PageSetup.PrintTitleRows = "$1:$12";//每页都打印的报表抬头
tagSheet.VPageBreaks.Add(tagSheet.Range["M1"]); //调整纵向分页符到最后一列 for (int r = ; r < ; r++)
{
tagSheet.Rows[r].RowHeight = ; //调整明细数据行高度
}
//部分复制其它数据表
for (int i = ; i <= wkBookTmp .Sheets.Count; i++)
{
int topPos = + * (i - );
int rightPos = + * (i - );
tagSheet.Range["A" + topPos].PageBreak = ;//在某行上方插入横向分页符 //删除默认的工作表
wkBookTag.Sheets["Sheet1"].Delete();
wkBookTag.Sheets["Sheet2"].Delete();
wkBookTag.Sheets["Sheet3"].Delete();
}
#endregion //............ //以16行为复制行,在后面批量插入15行(相当于在Excel中复制16行,再选中17后面的15行,再右键-》插入复制的行)
tagSheetPL.Rows["17:32"].Insert(XlDirection.xlDown, tagSheetPL.Rows[""].Copy()); //...... #region 结尾清理及更新操作日志
//保存并关闭完成所有操作的目标文件(xlOpenXMLWorkbook为.xlsx后缀,如果要.xls后缀,需要设置为xlOpenNormal
wkBookTag.SaveAs(tagFileFullName, XlFileFormat.xlOpenXMLWorkbook);
wkBookTag.Close(false);
wkBookTag = null;
//以下放在保存之后再关闭
wkBookTmpInvoice.Close(false);//不保存关闭
wkBookTmpInvoice = null;
File.Delete(tmpInvoiceFullName);//删除临时文件
}
catch (Exception ex)
{
if (wkBookTag != null) wkBookTag.Close();
if (wkBookTmpInvoice != null)
{
wkBookTmpInvoice.Close(false);//不保存关闭
File.Delete(tmpInvoiceFullName);//删除临时文件
}
}
finally
{ }
}
//插入字符,指定字体
if (!string.IsNullOrEmpty(MXRmk))
{
var objTextBox = wkSheet.Shapes.AddTextbox(Microsoft.Office.Core.MsoTextOrientation.msoTextOrientationHorizontal,uleft,utop, , );
objTextBox.Name = "TextBox1"; //这行必须的。它直接影响下一行。
//objTextBox.Fill.Visible = 0;
objTextBox.Line.Weight = ;
objTextBox.Line.ForeColor.RGB = Color.Black.ToArgb();
objTextBox.TextFrame2.TextRange.Characters.Text="【"+ MXRmk +"】";
objTextBox.TextFrame2.TextRange.Characters.Font.Size = ;
objTextBox.TextFrame2.TextRange.Characters.Font.Bold = Microsoft.Office.Core.MsoTriState.msoCTrue;
}
插入字符
//指定位置为A2处
float aleft = (float)partnoBarRange.Left+;
float atop = (float)partnoBarRange.Top;
float aheight = (float)partnoBarRange.Height; wkSheet.Shapes.AddPicture(tmpFN, Microsoft.Office.Core.MsoTriState.msoFalse, Microsoft.Office.Core.MsoTriState.msoTrue, aleft, atop, , aheight-);
插入二维码图片
if (chkPreviewFirst.Checked)
{
excelPrint.Visible = true;
wkSheet.PrintPreview(false);
}
else
{
excelPrint.Visible = false;
wkSheet.PrintOutEx();
}
打印预览与直接打印
。。。
C#下Excel的普通处理和报表设计的更多相关文章
- 微软BI 之SSRS 系列 - 实现 Excel 中图表结合的报表设计
来自群里面讨论的一个问题,EXCEL 中有类似于这样的图形,上面是 Chart, Chart X轴上的值正好就是下方 Table 的列头,这个在 SSRS 中应该如何实现? SSRS 2008.2 ...
- VSTO 学习笔记(六)在 Excel 2010中使用RDLC报表
原文:VSTO 学习笔记(六)在 Excel 2010中使用RDLC报表 Excel具有强大的图表显示.分析功能,这点毋庸置疑,但是如果将常规MIS系统中的数据以报表的形式在Excel中显示,却并不那 ...
- 加快FineReport报表设计的几个心得体会
加快FineReport报表设计的几个心得体会 一.从远程服务器大批量取数进行表样设计时,最好按“列顺序”取一个“空的SQL语句”,这样可提高设计速度.否则每次设计时模板均要从远程读取数据,速度相当慢 ...
- ActiveReports报表控件 V13 正式发布,提供在线报表设计和自适应报表布局
重磅消息, ActiveReports V13 正式发布!本次更新 ActiveReports 将给您带来全新的报表设计体验:提供在线报表设计器.提供响应式布局和屏幕尺寸自适应能力.提供全新的图表…… ...
- FastReport报表设计(仔细看)
FastReport报表设计 2011-06-16 16:56:19| 分类: 系统开发|举报|字号 订阅 下载LOFTER我的照片书 | 目录 5.1 前言 5.2 基本概念及操 ...
- FastReport报表设计
[转载]FastReport报表设计 (2012-10-24 20:37:26) 转载▼ 标签: 转载 原文地址:FastReport报表设计作者:小黑 FastReport报表设计 目录 5.1 ...
- PowerBI开发 第十一篇:报表设计技巧(更新)
PowerBI版本在持续的更新,这使得报表设计能够实现更多新的功能,您可以访问 PowerBI Blog查看PowerBI的最新更新信息,本文总结了PowerBI新版本的重要更新和设计技巧. 我的Po ...
- 再谈Cognos报表设计中的维度函数
在报表设计的过程中,客户很多时候会想看同比.环比的数据,很多人会想到利用日期函数在数据库中处理好然后直接在报表拖出来使用,其实这样加大了数据库的压力,当然也是解决问题的一种思路.今天我们就来说一下如何 ...
- JasperReport编译报表设计5
我们在前面的章节中产生的JasperReport模板(JRXML文件).这个文件不能直接用于生成报告.它必须被编译成JasperReport的“本地二进制"格式,称为Jasperfile.在 ...
随机推荐
- 关于Oracle to_char()函数中的IW,WW 周别显示
1)ww的算法为每年1月1日为第一周开始,date+6为每一周结尾 例如20050101为第一周的第一天,而第一周的最后一天为20050101+6=20050107 公式 每周第一天 :date + ...
- Python类(一)-实例化一个类
#-*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" class Person(): n = 123 #类变量 def __init_ ...
- Centos 6.* / 7.*下通过yum安装php7
查看 centos 版本 # cat /etc/centos-release 删除之前的 php 版本 # yum remove php* php-common rpm 安装 Php7 相应的 yum ...
- C# RSA的加解密与签名验证
最近做了一个CS架构的序列号生成器,用到 RSA加解密技术,以下是RSA的使用方法 RSA加密算法是一种非对称加密算法.在公钥加密标准和电子商业中RSA被广泛使用.RSA是1977年由罗纳德•李维斯特 ...
- c++builder PM2.5
c++builder PM2.5 TMemoryStream *ms = new TMemoryStream(); this->NetHTTPClient1->Get("http ...
- Linux系统设置Samba共享笔记
# "不允许一个用户使用一个以上用户名与服务器或共享资源的多重连接" C: 之前曾经与主机成功进行连接,连接断开后未将连接状态清除 $: net use */del /y # &q ...
- bash shell笔记1 脚本基础知识
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://twentyfour.blog.51cto.com/945260/505644 * ...
- vbs获取html内容
Dim content,name,password,arr,pos msg1="请输入ip和端口号地址"&chr(13)&chr(10)&"如ht ...
- AngularJS框架
http://www.runoob.com/angularjs/angularjs-intro.html
- ubuntu 12.04下搭建web服务器(MySQL+PHP+Apache) 教程
最近,经理让我搭建一个服务器,我从网上找了一篇比较好的教程,按教程一步步执行感觉挺顺利,所以准备整理一下这个教程.尊重原版注明出处:http://news.2ky.cn/Linux/ubuntu-12 ...