ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 清除选择区域内段首的空格

[复制链接]

TA的精华主题

TA的得分主题

发表于 2016-4-9 10:29 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
QQ截图20160409102343.jpg
---------------------------
上面三行实现了用3个宏定义了不同的字体和行距,想增加下:
在分别运行宏时,把各自段首的空格给删除,这可以实现吗,谢谢各位!

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-4-10 19:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
没人吗?
自己顶一个!

TA的精华主题

TA的得分主题

发表于 2016-4-11 11:00 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
整个宇宙唯一宏:
  1. Sub 删除段落首尾空格()
  2. '全选/居中/两端对齐
  3. '[方法1]
  4. '    SendKeys "^(aej)", True
  5. '[方法2]
  6. '    Selection.WholeStory
  7. '    Application.Run "CenterPara"
  8. '    Application.Run "LeftPara"
  9. '[方法3]
  10.     Selection.WholeStory
  11.     CommandBars.FindControl(ID:=122).Execute
  12.     CommandBars.FindControl(ID:=123).Execute
  13. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-4-12 00:26 | 显示全部楼层
413191246se 发表于 2016-4-11 11:00
整个宇宙唯一宏:

感谢se 的回复,3种方法都是在word2003测试。
第一种方法:没有清除行前的空格,只是全选了然后两端对齐。
第二种方法:一运行就卡死,看不到效果。
第三种方法:选择区域外的地方也替换了。
能否灵活一些,选择区域替换。

TA的精华主题

TA的得分主题

发表于 2016-4-13 15:25 | 显示全部楼层
楼主,确实我没好好看标题,清除选择区域内段首的空格。——该宏还真没有!下面我提供一下《删除所有空格》的宏,它的特点是:如果未选,则删除所有空格;如果选择了,则删除选定区域内所有空格。——你要的 宏还真没有,不过,似乎可以试试编程一下。
  1. Sub 删除所有空格()
  2.     Dim myRange As Range
  3.     If Selection.Type = wdSelectionIP Then Selection.WholeStory
  4.     Set myRange = Selection.Range
  5.     myRange.Find.Execute FindText:=" ", replacewith:="", Replace:=wdReplaceAll    '删除所有全角空格
  6.     myRange.Find.Execute FindText:="^w", replacewith:="", Replace:=wdReplaceAll    '删除所有空白区域
  7. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2016-4-13 15:34 | 显示全部楼层
成功——其实就是将选定区域居中,再居左,就删除了段首段尾空格:
Sub 删除选定区域段落首尾空格()
    CommandBars.FindControl(ID:=122).Execute
    CommandBars.FindControl(ID:=123).Execute
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-4-16 17:22 | 显示全部楼层
413191246se 发表于 2016-4-13 15:34
成功——其实就是将选定区域居中,再居左,就删除了段首段尾空格:
Sub 删除选定区域段落首尾空格()
     ...

谢谢!
但如果是用shitf+回车的换行符就无效了!

TA的精华主题

TA的得分主题

发表于 2016-4-18 14:31 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
那就先执行此宏即可:
  1. Sub 删除手动换行符和假段落标记()
  2.     ActiveDocument.Content.Find.Execute findtext:="^l", replacewith:="^p", Replace:=wdReplaceAll
  3.     ActiveDocument.Content.Find.Execute findtext:="^13", replacewith:="^p", Replace:=wdReplaceAll
  4. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-4-18 21:35 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2017-9-17 16:16 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
这个能否在同一文件夹里的多个word文档,批量处理?我试了下貌似不行??没有焦点
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-12 15:42 , Processed in 0.040115 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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