ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 601|回复: 31

[求助] VBA将选项对齐

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-3-1 20:22 | 显示全部楼层 |阅读模式
用VBA将选择题的选项对齐,比较美观,知道用制表符,但不知道如何操作。
Snipaste_2024-03-01_20-18-37.jpg

Snipaste_2024-03-01_20-19-07.jpg
将选项对齐.rar (16.03 KB, 下载次数: 29)

TA的精华主题

TA的得分主题

发表于 2024-3-2 01:57 | 显示全部楼层
* 小花鹿 老师:下面是我前两年写的《选项对齐》宏,请试运行之,代码仅供参考。
  1. Sub OptionAlign()
  2. '选项对齐
  3.     Dim t As Table, i As Paragraph, lenTable!, oTab!, Tab1!, Tab2!, Tab3!

  4.     With ActiveDocument
  5.         .Tables.Add .Range(0, 0), 1, 1
  6.         lenTable = Round(.Tables(1).Cell(1, 1).Width / 28.35, 2)
  7.         .Tables(1).Delete
  8.         'cm=char/2.7
  9.         oTab = (Int((lenTable - 2 * 0.19) * 2.7 + 0.5) - 2) / 4
  10.         Tab1 = Round((2 + 1 * oTab) / 2.7, 2)
  11.         Tab2 = Round((2 + 2 * oTab) / 2.7, 2)
  12.         Tab3 = Round((2 + 3 * oTab) / 2.7, 2)

  13.         .Content.Find.Execute "^l", , , 0, , , , , , "^p", 2

  14.         For Each t In .Tables
  15.             With t.Range.Rows
  16.                 .WrapAroundText = False
  17.                 .Alignment = wdAlignRowCenter
  18.             End With
  19.         Next

  20.         With .Content.Find
  21.             .Execute "(^13)([  ^s^t]{1,})", , , 1, , , , , , "\1", 2
  22.             .Execute "([  ^s^t]{1,})(^13)", , , 1, , , , , , "\2", 2
  23.             .Execute "([A-D])[.、]", , , 1, , , , , , "\1.", 2
  24.             .Execute "([  ^s^t^13]{1,})([B-D].)", , , 1, , , , , , "^t\2", 2
  25.             .Execute "(^13)([0-9]{1,})[.、]", , , 1, , , , , , "\1\2.", 2
  26.         End With

  27.         For Each i In .Paragraphs
  28.             With i.Range
  29.                 If Not .Information(12) Then
  30.                     If .Text Like "A.*" Then
  31.                         .Font.Color = wdColorRed

  32.                         With .ParagraphFormat.TabStops
  33.                             .ClearAll
  34.                             .Add Position:=CentimetersToPoints(Tab1)
  35.                             .Add Position:=CentimetersToPoints(Tab2)
  36.                             .Add Position:=CentimetersToPoints(Tab3)
  37.                         End With

  38.                         If .ComputeStatistics(1) = 2 Then
  39.                             .Find.Execute "^t(C.)", , , 1, , , , , , "^p\1", 2
  40.                             With .ParagraphFormat.TabStops
  41.                                 .ClearAll
  42.                                 .Add Position:=CentimetersToPoints(Tab2)
  43.                             End With
  44.                         ElseIf .ComputeStatistics(1) >= 3 Then
  45.                             .Find.Execute "^t([B-D].)", , , 1, , , , , , "^p\1", 2
  46.                         End If

  47.                         With .ParagraphFormat
  48.                             .CharacterUnitFirstLineIndent = 0
  49.                             .FirstLineIndent = CentimetersToPoints(0)
  50.                             .CharacterUnitFirstLineIndent = 2
  51.                         End With
  52.                     End If
  53.                 End If
  54.             End With
  55.         Next
  56.     End With
  57. End Sub
复制代码

评分

3

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-3-2 08:27 | 显示全部楼层
413191246se 发表于 2024-3-2 01:57
* 小花鹿 老师:下面是我前两年写的《选项对齐》宏,请试运行之,代码仅供参考。

哈哈哈 老师   我就记得 有老师写过这个代码刚刚找这个原贴 没找到  

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-2 09:09 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
谢谢两位老师                                                                                                               

TA的精华主题

TA的得分主题

发表于 2024-3-2 09:38 | 显示全部楼层
413191246se 发表于 2024-3-2 01:57
* 小花鹿 老师:下面是我前两年写的《选项对齐》宏,请试运行之,代码仅供参考。

问一下,如果有5-6个选项,应该如何处理

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-2 11:32 | 显示全部楼层
2楼代码运行结果与我图片不一样,题号为11、12两个小题的选项本来是不用换行的

TA的精华主题

TA的得分主题

发表于 2024-3-2 16:42 | 显示全部楼层
小花鹿 发表于 2024-3-2 11:32
2楼代码运行结果与我图片不一样,题号为11、12两个小题的选项本来是不用换行的

因为文档中的制表符是理想状态,代码生成的是平分位置

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-2 18:50 | 显示全部楼层
batmanbbs 发表于 2024-3-2 16:42
因为文档中的制表符是理想状态,代码生成的是平分位置

我图片的效果是手动设置的,VBA应该能完成这样的效果                                             

TA的精华主题

TA的得分主题

发表于 2024-3-3 01:46 | 显示全部楼层
* batmanbbs 老师,我的代码默认是 4 个(也许 5 个?我忘了!),如果有 5、6 个选项,需要自行扩充代码了!制表位要重新计算。
* 还有,小花鹿 老师、草莽 老师:运行本宏前要自行进行公文排版。
* 也许各位能重新编制出自行适应多个选项的宏,仅作抛砖引玉吧!

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-3 19:38 | 显示全部楼层
想了很长时间,觉得这个问题太复杂,没有思路                                                                        
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-5-6 05:58 , Processed in 0.047419 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表