EXCEL中VBA的一些应用.docVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
EXCEL中VBA的一些应用

EXCEL中VBA的一些应用(1) 1、编写“宏”让Excel自动合并选中单元格内容   在用Excel整理表格数据时,希望能够自动合并选中区域内所有单元格的内容,但是Excel软件自带的合并功能无法满足这个要求,应该怎么办呢?   我们可以编写一个“宏”来实现,它可以巧妙地保存选区中所有单元格内的数据,通过循环赋值到一个变量中,最后再将结果输出到合并后的单元格内。 代码如下: Sub 合并单元格() 关闭屏幕更新和警告提示 Application.ScreenUpdating = False Application.DisplayAlerts = False Dim i% 循环统计选中区域的单元格数据并将其合并到StrTotal中 For i = 1 To Selection.Count StrTotal = StrTotal Selection.Cells(i) Next 设置选区格式 With Selection .MergeCells = True .HorizontalAlignment = xlCenter .VerticalAlignment = xlCenter .Value = StrTotal? 在合并数据前加 号 End With 恢复屏幕更新和警告提示 Application.DisplayAlerts = True Application.ScreenUpdating = True End Sub   将上面的宏指定给一个自定义的工具栏按钮。接下来我们就可以测试一下结果了,如在几个不相邻的单元格内依次输入不同的数据(可以是文字、字母或数字),最后选中所有的数据区域,单击刚才自定义的按钮,就可以看到合并的效果了。 用VBA代码编写一键插入Excel斜线表头 有的时候,我们要在Excel中添加斜线表头,可Excel并没有提供制作斜线表头的功能,每次都要手工画一条斜线,非常麻烦。有没有解决方法呢?其实,我们可以利用VBA代码可以编写一个功能,一键插入Excel斜线表头。   用“控件工具箱”中的“命令按钮”控件,在工作表中绘制一个命令按钮,将“Caption”属性改为“一键插入斜线表头”,双击该按钮,在“Click”事件中编写代码,其中关键代码如下。 关键代码:   获取行标题和列标题   Dim icol, irow As String   icol=InputBox(请输入斜线单元格的行标题, 行标题)   irow=InputBox(请输入斜线单元格的列标题, 列标题)   Selection.Value = icol + ??? + irow   判断字符串是否符合规定   If Len(icol) = 0 or Len(irow) = 0 Then   MsgBox (输入的标题为空!)   Exit Sub   End If   判断选区是否只有一个单元格   If Selection.Count 1 Then   MsgBox (请选择一个单元格再执行此操作!)   Exit Sub   End If   设置左上至右下的斜线   With Selection.Borders(xlDiagonalDown)   .LineStyle = xlContinuous   .Weight = xlThin   .ColorIndex = xlAutomatic   End With   代码编写好以后,需要插入斜线表头的时候,先选中需要插入斜线表头的单元格(如果选中的单元格超过一个,系统会给出错误提示),单击“一键插入斜线表头”按钮,系统会提示输入表头的行、列标题,分别输入表头的行标题(例如星期)和列标题(例如班级)即可。非常方便。 编写Excel宏 轻松完成单元格数据互换 如何实现Excel表格中两个单元格区域间的数据交换呢?通常我们使用剪切粘贴的方法来完成,但这个方法比较繁琐,如果数据区域较大还容易出错。下面我们试着来编写一个可以实现该功能的“宏”吧。   打开“工具”菜单中的“宏”,选择“录制新宏”命令,在个人宏工作簿中(Personal.xls)创建一个名为Exchange 的宏,代码如下: 代码:   判断用户是否选择了两个单元格或单元格区域   If Selection.Areas.Count = 2 Then   Set XR = Selection.Areas(1)   Set YR = Selection.Areas(2)   判断选区是否重叠   If Not Intersect(XR, YR) Is Nothing Then   Result = MsgBox( 选择区域有重叠!交换后重叠区域的数据将有部份被覆盖! vbCrLf 是否继续?, vbYesN

文档评论(0)

cuotian + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档