ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 为何无法替换掉word中所有图片的“首行缩进”?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-3-3 15:45 | 显示全部楼层 |阅读模式
我想一次将所有图片的“首行缩进”取消掉,用替换的办法发现不管用,不知道问题出在哪里呢?


取消图片缩进.rar (350.47 KB, 下载次数: 6)

TA的精华主题

TA的得分主题

发表于 2023-3-3 19:11 | 显示全部楼层
经测试,仅替换段落缩进确实替换不了,此处提供以下面两种方法:
方法一、Word VBA代码
(代码也可以用替换,此处就用其他方法了)
  1. Function 纯文本(ByVal myString As String) As String
  2.     Dim s As String
  3.    
  4.     s = myString
  5.     s = Replace(s, " ", "")
  6.     s = Replace(s, " ", "")
  7.     s = Replace(s, vbTab, "")
  8.     s = Replace(s, Chr(7), "")
  9.     s = Replace(s, Chr(11), "")
  10.     s = Replace(s, Chr(13), "")
  11.     s = Replace(s, Chr(160), "")
  12.    
  13.     纯文本 = s
  14. End Function

  15. Sub 图片段居中()
  16.     Dim pa As Paragraph
  17.     Dim ispCount As Integer
  18.     Dim lenTrim  As Integer
  19.     For Each pa In ActiveDocument.Paragraphs
  20.         ispCount = pa.Range.InlineShapes.Count
  21.         If ispCount > 0 Then
  22.             lenTrim = Len(纯文本(pa.Range.Text))
  23.             If ispCount = lenTrim Then
  24.                 With pa.Range
  25.                     .Style = pa.Range.Document.Styles("正文") '设置样式为正文以免影响其他位置格式,可省
  26.                     .ParagraphFormat.CharacterUnitFirstLineIndent = 0 '设置首行字符缩进为0
  27.                     .ParagraphFormat.FirstLineIndent = 0 '设置首先缩进0磅
  28.                     .ParagraphFormat.Alignment = wdAlignParagraphCenter '图片居中
  29.                 End With
  30.             End If
  31.         End If
  32.     Next
  33. End Sub
复制代码

image.jpg


image.jpg


取消图片缩进.rar

710.99 KB, 下载次数: 5

打开docm文件测试

TA的精华主题

TA的得分主题

发表于 2023-3-3 23:07 | 显示全部楼层
守候老师:你没用“CentimetersToPoints(0)”直接用 0 也管用,经测试没有问题。

TA的精华主题

TA的得分主题

发表于 2023-3-4 22:08 | 显示全部楼层
413191246se 发表于 2023-3-3 23:07
守候老师:你没用“CentimetersToPoints(0)”直接用 0 也管用,经测试没有问题。

TA的精华主题

TA的得分主题

发表于 2023-3-5 20:03 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2023-3-5 21:51 | 显示全部楼层
wuwenbin32415 发表于 2023-3-5 20:03
不用vba,用基础的操作方法(替换)怎么做?

替换 我上面第二种方法就是

TA的精华主题

TA的得分主题

发表于 2023-3-6 22:37 | 显示全部楼层
谢谢守候老师,我有2个问题请教:1、为什么替换为一定要有“格式”里的“样式”、“正文”?如果没有这个而只有“格式”里的“段落” 、“特殊格式”、“(无)”就没有效果。2、替换时在查找框里输入“图形”即^g会有效,但是单纯查找时用“图形”即^g却查找不到这4张图片,只能选中一张(最后一张),这是为什么?

TA的精华主题

TA的得分主题

发表于 2023-3-6 22:50 | 显示全部楼层
wuwenbin32415 发表于 2023-3-6 22:37
谢谢守候老师,我有2个问题请教:1、为什么替换为一定要有“格式”里的“样式”、“正文”?如果没有这个而 ...

1.具体原因尚不清楚,但很可能和手动设置过格式有关
2.经测试
(1)【^g】在查找/替换/导航都有效,只是查找的时候不能像其他文字一次全选;
(2)在通配符模式下没有查找图片功能

TA的精华主题

TA的得分主题

发表于 2023-3-7 15:08 | 显示全部楼层
谢谢守候老师,^g好像只能查找到嵌入型的图片,不能找到非嵌入型的图片,是这样吧?

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-3-7 16:21 | 显示全部楼层
守候_CJ 发表于 2023-3-3 19:11
经测试,仅替换段落缩进确实替换不了,此处提供以下面两种方法:
方法一、Word VBA代码
(代码也可以用替 ...

感谢指教,研究好几天没明白什么原因
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-22 16:30 , Processed in 0.041482 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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