当前位置: 首页 > news >正文

建设网站个人简介范文app下载推广平台

建设网站个人简介范文,app下载推广平台,wordpress单位内网做网站,博客可以做网站收录用的吗Office自带的VBE在编辑代码时,没有自动完成代码缩进的功能,而我们在网上找到的VBA代码,经常没有实现良好的自动缩进,复制到VBE后,可读性较差。本文介绍的宏,通过使用vbscript.regexp对象,利用正…

Office自带的VBE在编辑代码时,没有自动完成代码缩进的功能,而我们在网上找到的VBA代码,经常没有实现良好的自动缩进,复制到VBE后,可读性较差。本文介绍的宏,通过使用vbscript.regexp对象,利用正则表达式匹配VBA 代码块中开始和结束关键字,完成缩进量的计算,从而实现VBA代码的格式化。
要使用vbscript.regexp对象,需要用过VBE的“工具”菜单的“引用”命令引入Microsoft VBScript Regular Expressions 5.5这个库。引入这个库后,我们构筑三个正则表达式,分别匹配VBA代码块的开始记号、结束记号及中继记号。例如一个If-Else-End If代码块,If就是这个代码块的开始记号,遇到了开始记号,下面的行就需要增加一个缩进单位;Else就是这个代码块的中继记号,遇到中继记号,不影响后续行的缩进,但本行的缩进需要减少一个单位;End If就是这个代码块的结束记号,遇到结束记号,本行和后续各行的缩进量就要减少一个单位。此外还有一个特殊情况,就是换行连接符“_”,其后续第一行也宜增加一个缩进量,如果下一行仍然太长被分行,则再下面一行不用继续增加缩进。
宏代码如下,运行宏前需先选择复制到Word文档中的整个代码块。如果所选择的代码中包含的所有代码块结构完整,则所选择的代码块被替换为缩进规范的代码。如运行宏后发现代码缩进不正确,则代码中肯定有错误,存在结构不完整的代码块。

Sub VBA代码缩进()Dim aPara As ParagraphDim CumulativeIndent As Integer, currParaIndent%, i%Dim sTmp As String, sResult$Dim regRight As RegExp, regLeft As RegExp, regMiddle As RegExpSet regRight = CreateObject("vbscript.regexp")Set regLeft = CreateObject("vbscript.regexp")Set regMiddle = CreateObject("vbscript.regexp")'regLeft匹配需要增加后续段落左缩进的段落,即段落开头为代码块开始记号的段落regLeft.Pattern = "^(for|while|if|#if|with|do|select|((public|private)\s+)*(sub|function))\s"regLeft.IgnoreCase = True'regRight匹配需要减少本段及后续段落左缩进的段落,即段落开头为代码块结束记号的段落regRight.Pattern = "^(end\s|#end\s|loop|next|wend)"regRight.IgnoreCase = True'regMiddle匹配对前后段落缩进没有影响,但需要减少本段左缩进的段落,即段落开头为中继记号的段落regMiddle.Pattern = "^(elseif|else|#elseif|#else|case)\s"regMiddle.IgnoreCase = True'将所选择的代码原有不规范的缩进全部删除,即替换掉各段前导空格或制表符(^t),以免影响最终缩进With Selection.Find.MatchWildcards = True.Execute FindText:="^13[ ^t]{1,}", _ReplaceWith:="^p", Replace:=wdReplaceAllEnd With'记录一行代码前累计需添加的缩进量CumulativeIndent = 0For Each aPara In Selection.Paragraphs'将当前段落文本读入临时字符串,去掉前后空白sTmp = Trim(aPara.Range.Text)'计算缩进量'遇到代码块开始记号,左缩进增加1(注意本段增加的缩进后面需要减掉)If regLeft.test(sTmp) ThenCumulativeIndent = CumulativeIndent + 1'遇到代码块结束记号,左缩进减少1ElseIf regRight.test(sTmp) ThenCumulativeIndent = CumulativeIndent - 1End If'计算本段的段落缩进,如果本段为代码块开始记号或者是中间记号开头,'需要将本段前面加上的缩进量调整回去If regLeft.test(sTmp) Or regMiddle.test(sTmp) ThencurrParaIndent = CumulativeIndent - 1ElsecurrParaIndent = CumulativeIndentEnd If'根据需要添加的缩进量,在本段文本前添加TAB(Chr(9))For i = 1 To currParaIndentsTmp = Chr(9) & sTmpNext'如果上一行末尾是换行连接符,下一行增加一个TAB进行缩进'由于没有修改CumulativeIndent,所以这个操作不会影响其他行的缩进量 If Right(sResult, 1) = "_" ThensTmp = Chr(9) & sTmpEnd If'将添加了TAB的字符串拼接到结果字符串中sResult = sResult & sTmpNextSelection.Text = sResult
End Sub
http://www.mmbaike.com/news/57555.html

相关文章:

  • 青岛搜客网站建设公司流量网站
  • 漳州正规网站建设价格推广app大全
  • 淘宝网店网站建设目的uc信息流广告投放
  • 综合型网站建设网络销售平台
  • 做网站是用ecs还是虚拟主机网推
  • 息烽做网站公司有哪些百度seo公司哪家强一点
  • python做网站是不是特别慢天津seo托管
  • 做纯静态网站怎么样海外推广渠道都有哪些
  • 成都市网站建设免费建站网站大全
  • wordpress的配置文件怎么写搜索引擎推广seo
  • 蚌埠网站建设网站网店代运营靠谱吗
  • 网站建设对电子商务的意义seo指导
  • 怎么建设网站怎么样seo咨询服务
  • 网站域名怎么写如何做企业网页
  • 专注合肥网站建设营销型网站分析
  • 美女做丝袜广告视频网站自动收录网
  • 定制网站制作公司怎么样网络营销心得体会1000字
  • 平台网站可以做第三方检测报告什么是交换链接
  • 南宁网站推广优化相城seo网站优化软件
  • 扬州网站商城建设价格八宿县网站seo优化排名
  • wordpress 页面很窄学seo需要学什么专业
  • 华强北网上商城百度关键词seo公司
  • 郑州新冠疫情最新消息今天淘宝怎么优化关键词排名
  • 汉口网站建设 优帮云网站建设与优化
  • 徐老师在那个网站做发视频下载微博推广效果怎么样
  • 广东企业备案 网站建设方案书网络推广好做吗?
  • 新闻网站广告怎么做如何开发一个网站
  • 安庆做网站哪个公司好web前端培训费用大概多少
  • 做网站首页文件淘宝网店怎么运营起来
  • 军人可以做网站吗微信公众号推广