首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

VB.NET 第三方 EPPLUS 操作类库应用笔记

://epplussoftware.com/docs/5.0/api/index.html ---- 一,EPPLUS 介绍(版本 5.8.0.0)   EPPlus使用 Open Office XML...EPPlus 支持:(单元格范围,单元格样式(边框,颜色,填充,字体,数字,对齐),图表,图片,形状,批注,表格,保护,加密,数据透视表,数据验证,条件格式,VBA,公式计算等等) 1.1 ExcelPackage...该类实现了 IDisposable 接口,也就是说可以使用 using 进行对象释放。   不管构造函数中传入的参数是否有效,该类的 Workbook 属性都会自动创建,无须担心空指针问题。   ...2.2.1 公式计算(下面演示两条求和公式) xlsht.Cells("C1:D1").Formula = "A1*B1" ''这是乘法的公式,意思是A1单元格的值乘B1的值赋值给C1,然后B1的值乘...xlsht.Cells.Style.WrapText = True ''所有单元格自动换行 2.2.4 设置单元格字体样式 xlsht.Cells("A1:D4").Style.Font.Bold

5.5K20
您找到你想要的搜索结果了吗?
是的
没有找到

VBA小技巧09:从非连续的单元格区域复制到指定单元格区域

本文将给出一段VBA代码,从非连续的单元格区域复制值并粘贴到另外指定的单元格区域。 如下图1所示,右侧两个单元格区域的数据复制到左侧的两个单元格区域中。 ? 图1 下图2是粘贴数据后的结果。 ?...但是,我们可以使用VBA来完成。 首先定义数据区域名称和要复制到的区域的名称。 如下图4所示,单元格区域H2:K4和G7:J9定义名称为“copyrng”。 ?...图4 同样,单元格区域C2:F4和B7:E9定义名称为“pasterng”,如下图5所示。 ?...,多个区域中间使用“,”隔开,而其中“:”号的个数就是引用的单元格区域数,所以代码: Len(strAddress) -Len(Application.WorksheetFunction.Substitute...由于每个区域都属于Areas集合,使用一个循环遍历各个区域并执行复制粘贴操作。 运行CopyRange过程,即可实现上图2所示的效果。

2.9K40

如何在合并单元格使用公式计算装车时间

今晚在学员群里看到一个很有挑战性的问题 大概的数据案例如下 第一想法是使用INDIRECT函数,例如第一个合并单元格,可以用下面得出答案 =INDIRECT("C7")-INDIRECT("B2"...合并单元格的实质是什么?...就是把内容(公式,数值等)放在合并单元格的左上角,其他单元格都变成空值 根据这个实质,我们可以对单元格进行统计分组,所以有了辅助列2,需要巧妙的用COUNTA函数 因为合并单元格之间都是空,所以会自动统计合并单元格数量...这里有个小技巧:注意最开始的单元格是固定的,这样下拉会使范围越来越大 好了,我们根据这两列可以求到每个合并单元格最开始的行号和列号了 最开始的行号=第一个合并单元格分组号 最末尾的行号=第一个合并单元格分组号...+组员数-1 使用MATCH函数找到第一个分组号,返回对应的辅助列1的内容,就是合并单元格最开始的行号 在第一个思路的基础上,加上分组组员数量,减1,即得到末尾行号 回到最开始的思路 =INDIRECT

74210

如何在合并单元格使用公式计算装车时间

提问 今晚在学员群里看到一个很有挑战性的问题图片 [图片] 大概的数据案例如下 [在这里插入图片描述] 解答 第一想法是使用INDIRECT函数,例如第一个合并单元格,可以用下面得出答案 =INDIRECT...合并单元格的实质是什么?...就是把内容(公式,数值等)放在合并单元格的左上角,其他单元格都变成空值 根据这个实质,我们可以对单元格进行统计分组,所以有了辅助列2,需要巧妙的用COUNTA函数 [在这里插入图片描述] 因为合并单元格之间都是空...,所以会自动统计合并单元格数量 ==这里有个小技巧:注意最开始的单元格是固定的,这样下拉会使范围越来越大== 用INDEX和MATCH求开始行和结束行 好了,我们根据这两列可以求到每个合并单元格最开始的行号和列号了...最开始的行号=第一个合并单元格分组号 最末尾的行号=第一个合并单元格分组号+组员数-1 [在这里插入图片描述] 使用MATCH函数找到第一个分组号,返回对应的辅助列1的内容,就是合并单元格最开始的行号

1K00

Excel公式技巧27: 在条件格式中使用公式来突出显示单元格

选择“使用公式确定要设置格式的单元格” 2. 在“为符合此公式的值设置格式”框中输入适当的公式 3. 单击“格式”按钮,设置想要的格式。 ? 图1 本文以交替突出显示所选单元格区域颜色为例来讲解。...如下图2所示,给单元格区域中偶数行添加背景色。 ? 图2 可使用公式: MOD(ROW(),2)=0 其运算过程如下图3所示: ?...图3 可以清楚地看到,公式中ROW()返回当前单元格所在行的行号;MOD(ROW(),2)返回行号除以2后的余数,要么是0(偶数行),要么是1(奇数行);MOD(ROW(),2)与0相比较:MOD(ROW...同样,如果想为奇数行设置格式,则使用公式: MOD(ROW(),2)=1 结果如下图4所示。 ? 图4 如果要对偶数列设置格式,则使用公式: MOD(COLUMN(),2)=0 结果如下图5所示。...这样,可以使用公式: ISODD(ROW()+COLUMN()) 如果要求变换突出显示的单元格,可以使用公式: ISEVEN(ROW()+COLUMN()) 结果如下图8所示。 ? 图8

2.8K20

epplus word html,EPPlus简介

简介:Epplus是一个使用Open Office XML(Xlsx)文件格式,能读写Excel 2007/2010文件的开源组件 功效:支持对excel文档的汇入汇出,图表(excel自带的图表基本都可以实现...)的列印 使用:首先应该下载Epplus的dll文件 1.添加dll文件至工程bin文件中 2.添加引用 using OfficeOpenXml; using OfficeOpenXml.Drawing...,这里多说一句,NPOI必须先创建单元格,然后再给单元格赋值,而Epplus不需要,直接找到单元格进行赋值就可以了. worksheet.Cells[int row, int col].Value =...//读取指定单元格的计算公式 worksheet.Cells[3, 5].FormulaR1C1 //读取指定单元格的R1C1引用方式的公式 看了EPPlus的Sample1到7,其中Sample4是根据现有模板文件导出...Sample1 基本的导出Excel Sample2 读取Excel Sample3 数据库的数据导出到Excel,以及在Excel中如何指定单元格为超链接样式 Sample4 根据现有模板文件导出Excel

1.9K41

EPPlus使用

公式计算 excel中离不开各种各样的公式计算,在Epplus中运用公式有两种方式,你都可以尝试一下: worksheet.Cells["D2:D5"].Formula ="B2*C2";//这是乘法的公式...string.Format("SUBTOTAL(9,{0})",new ExcelAddress(2, 2, 5, 2).Address);//这是自动求和的方法,至于subtotal的用法你需要自己去了解了 至于别的公式大家可以自己尝试一下...设置单元格格式 worksheet.Cells[5, 3].Style.Numberformat.Format ="#,##0.00";//这是保留两位小数 单元格的格式设置还有很多,我就不一一列出来了...,基本上excel上能实现的Epplus都能实现,大家可以去Epplus的源码上看。.../边框样式 shape.SetPosition(200, 300);//形状的位置 shape.SetSize(80, 30);//形状的大小 shape.Text ="test";//形状的内容 Epplus

1.3K20

Excel - 使用公式秒转换为分+秒

对于这种场景,可以通过Excel的公式来实现。...先在B1单元格输入以下公式: 1 =INT(A2/60)&"min,"&ROUND(MOD(A2,60),0)&"s" 输入之后,你会发现该单元格的内容就变成了8min,3s。...这里的INT(a)表示数值a向下取整为最接近的整数,ROUND(a, b)表示按照b的位数来a四舍五入,MOD(a, b)表示a除以b的余数,&表示拼接字符串。...现在可以对一个单元格进行公式求值了,接着按住该单元格的右下角,鼠标会变成一个+号,按住不放向其它方向拖动,可以将对应的单元格自动填充该公式。...如果希望在单元格内进行换行,在需要换行的地方按下Alt + Enter组合键即可。 警告 本文最后更新于 November 22, 2018,文中内容可能已过时,请谨慎使用

95210

Excel公式练习32: 包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格

本次的练习是:如下图1所示,单元格区域A1:D6中是一系列数据,其中包含空单元格,现在要将它们放置到一列中,并删除空单元格,如图中所示的单元格区域G1:G13,如何使用公式实现? ?...公式 1.先将单元格区域A1:D6命名为“rngData”。 2.在单元格F1中输入公式: =SUM(COUNTIF(rngData,{">0","?...这个结果传递给INDIRECT函数: INDIRECT(“R1C00004”,0) 结果取出第1行第4列中的值,即单元格D4中的值。 为什么选用10^5,并且使用R0C00000作为格式字符串呢?...使用足够大的数值,主要是为了考虑行和列扩展后能够准确地取出相应行列所在单元格的数据。 注意到,在TEXT函数中,先填充C之后的五个零,剩下的在填充R之后的部分。...其他解 还可以使用公式: =IFERROR(INDIRECT(TEXT(SMALL(IF(rngData"",10^5*ROW(rngData)+COLUMN(rngData)),ROWS($1:1

2.2K10

Excel公式练习33: 包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格(续)

这里,需要以列的方式进行,即先放置第1列中的数据、再放置第2列中的数据……依此类推,最终结果如图中所示的单元格区域H1:H13,如何使用公式实现? ? 图1 先不看答案,自已动手试一试。...公式 1.先将单元格区域A1:D6命名为“rngData”。 2.在单元格F1中输入公式: =SUM(COUNTIF(rngData,{">0","?...3.在单元格H1中输入数组公式: =IF(ROWS($1:1)>$F$1,"",INDIRECT(TEXT(SUM(10^{5,0}*MID(TEXT(SMALL(IF(rngData"",10^5...公式解析 公式中的主要部分与上篇文章相同,不同的是: TEXT(SMALL(IF(rngData"",10^5*ROW(rngData)+COLUMN(rngData)),ROWS($1:1)),...相关参考 Excel公式练习32:包含空单元格的多行多列单元格区域转换成单独的列并去掉空单元格 Excel公式练习4:矩形数据区域转换成一行或者一列

2.1K10

Excel催化剂开源第16波-VSTO开发之脱离传统COM交互以提升性能

EPPLUS的话,只能用于xml结构的xlsx文档,因此实现的接口好用,若只针对xlsx版格式的文档读写,首选EPPLUS。...最终牺牲了一些程序大小问题,但Excel催化剂已在前述文章中提及,引用dll文件分离将不影响我们后续的升级功能时的升级性能,总体来说,还是可以取得很好的平衡性。...在Excel催化剂上的使用场景 数据导出场景 在前一波中提到,DataTable的数据导出Excel单元格区域上,我们已经提及到若数据量大,改用EPPLUS来导出,在EPPLUS上将数据导出到工作表,只需一个现成的已封装好的方法...遍历单元格属性 同样的,若不是仅仅获取单元格上的数据,而是需要获取单元格的其他属性如字体颜色、填充颜色、字号、字体名称、样式等信息时,用COM访问的方式,也是有十分大的性能瓶颈问题。...在Excel单元格管理相关功能上,大量使用EPPLUS类库作这些的遍历访问,性能十分优秀。

88330

个人永久性免费-Excel催化剂功能第74波-批量排版格式利器,瞬间美化表格

一般内容部分是准确的,可用于其他渠道引用使用的,如Excel数据内容复制到记事本中。...保护:可用于锁定单元格不让用户修改和显示与否公式计算逻辑等控制。 外加上形状、图片的悬浮于单元格之上的元素,真的可发挥控制的余地非常大。...对单元格设置某样式,后期若不满意当前设置的样式,可通过修改样式的配置,瞬间对引用了该样式的单元格区域群进行格式的修改 单元格样式之于单个格式来说,可对其进行多个格式的组合并命名其组合,方便与其他人分享交互等优点...类似于查找替换中的格式搜索,先根据指定单元格的格式来设置搜索的格式,如下图所示的所有常用格式中,都是并且的关系,若需要搜索多种格式,可勾选对应的复选框,以多个条件并且的方式来搜索。...,性能更优 小技巧2: 因程序使用EPPLUS 的开源类库来读取或搜索所有单元格,会对活动原工作薄进行关闭后再读取和写入结果表,操作完成后再打开保存后结果表的工作薄。

1.1K10
领券