ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] WORD中选择最后一个字符至最后一个回车符号的VBA代码。怎么写。

[复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-1-22 22:01 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
loquat 发表于 2015-1-22 21:17
以上思路只是在批量编辑时可能会效率比较明显,单个文件5楼是最好的代码。。。

感谢老师的代码,但,最后的空格不能删除!

TA的精华主题

TA的得分主题

发表于 2015-1-23 09:57 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
学习VS交流 发表于 2015-1-22 22:01
感谢老师的代码,但,最后的空格不能删除!

以下代码删除文档尾部连续的空白段落,注意,是空白段落而非空格.
Sub DeleteLastBlankParagraphs()
''''功能:删除文档结尾位置的空白段落
    Dim myRange As Word.Range
    With ActiveDocument.Content.Find ''''主文字部分的查找
        .ClearFormatting ''''清除查找格式
        .Text = "^13{2,}"    ''''[^13^32]{2,}''''此要为连续2个及以上空白段落;如需包括空格,参考注释后的表达式
        .Wrap = wdFindStop ''''完成搜索后即结束
        .Forward = False ''''反向查找(从文档尾部向文档起始位置方向)
        .MatchWildcards = True ''''使用通配符
        .Replacement.ClearFormatting ''''清除替换格式
        .Replacement.Text = Empty ''''清空替换内容
        If .Execute = True Then ''''如果成功查找到时
            Set myRange = .Parent ''''返回找到的Range对象
            ''''myRange.Select
            If myRange.End = ActiveDocument.Content.End Then myRange.Delete ''''如包含文档结束标记则删除之
        End If
    End With
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-1-23 10:01 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
守柔 发表于 2015-1-23 09:57
以下代码删除文档尾部连续的空白段落,注意,是空白段落而非空格.
Sub DeleteLastBlankParagraphs()
'''' ...

守柔老师你好,非常感谢你的帮助!

如果我想删除最后一个字符后面,所有的空格和空白段落
再帮我修改下好吗,谢谢老师了!

TA的精华主题

TA的得分主题

发表于 2015-1-23 10:43 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
学习VS交流 发表于 2015-1-22 22:01
感谢老师的代码,但,最后的空格不能删除!

Sub DeleteLastBlankCharacters()
''''功能:删除文档结尾位置的空白段落和空格
    With ActiveDocument.Content
        .InsertAfter Chr$(13) & Chr$(8)    ''''文档结束标记之前插入一个特殊字符(辅助定位)
        With .Find
            .ClearFormatting    ''''清除查找格式
            ''''如有需要其他空白字符,请自行添加
            .Text = "[^13^32" & ChrW$(160) & ChrW$(12288) & "]@^8"    ''''查找连续的空白段落,半角空格,全角空格,不连续空格
            .Wrap = wdFindStop    ''''完成搜索后即结束
            .Forward = True    ''''正向查找
            .MatchWildcards = True    ''''使用通配符
            .Replacement.ClearFormatting    ''''清除替换格式
            .Replacement.Text = Empty    ''''清空替换内容
            .Execute Replace:=wdReplaceAll    ''''全部替换
        End With
    End With
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-1-23 10:49 | 显示全部楼层
守柔 发表于 2015-1-23 10:43
Sub DeleteLastBlankCharacters()
''''功能:删除文档结尾位置的空白段落和空格
    With ActiveDocumen ...

老师这个完美了

如果是删除文档开始第一个字符前的空格和空白段落

麻烦老师也帮我修改一下好吧,谢谢老师了!

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-1-23 16:25 | 显示全部楼层
守柔 发表于 2015-1-23 16:15
可以吐槽一下吧?
菩提本无树,明镜亦非台,本来无一物,何处惹尘埃.

谢谢老师,这个很好用!非常感谢!

TA的精华主题

TA的得分主题

发表于 2015-1-25 16:45 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
学习VS交流 发表于 2015-1-22 22:01
感谢老师的代码,但,最后的空格不能删除!

Sub 删除空行()
     Dim i As Paragraph
     For Each i In ActiveDocument.Paragraphs
         If Len(Trim(i.Range)) = 1 Then i.Range.Delete
     Next
End Sub

TA的精华主题

TA的得分主题

发表于 2020-3-8 11:23 | 显示全部楼层
413191246se 发表于 2015-1-21 00:26
明白了!楼主,我觉得你的要求似乎没有必要用代码,批量处理还是要删除全部空行的再排版,但也给你提供一下 ...

5楼的代码和10楼的我都用了试了一下。有一点不同的是,如果word文档是以表格结尾的话,在表格下面始终有一个空白段落,怎么删它都还在,这样5楼这个代码的程序按理论上讲就无法自动结束运行。如果文档末尾是文字而不是表格的话就不会出现在这个问题。10楼的代码不存在这个问题,只删除一次。

TA的精华主题

TA的得分主题

发表于 2021-5-12 00:47 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
* 刚才在查找本坛“假回车符”的问题时,刚好看到本帖。
* 确实如楼上朋友所言,如果文尾有表格的话(表格最后的回车符不能删除,否则怎么输入下一个字符呢?这和新建文档只有一个段落标记是一个道理),程序不能自动终止。如果文尾有表格,则分两种情况:一是表格后有文字;二是表格后无文字只有空格。
* 下面的宏已经更正,请各位试用:
  1. Sub aaaa_DeleteBlanks_DocEnd()
  2.     With Selection
  3.         .EndKey 6
  4.         Do
  5.             If .Previous.Information(12) Then Exit Do
  6.             CommandBars.FindControl(ID:=122).Execute
  7.             CommandBars.FindControl(ID:=123).Execute
  8.             If .Paragraphs(1).Range = vbCr Then .Delete Else Exit Do
  9.         Loop
  10.     End With
  11. End Sub
复制代码
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

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

GMT+8, 2024-4-19 01:02 , Processed in 0.040455 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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