win32com操作word API精讲 第六集 Range(四)对齐和缩进
本课程《win32com操作word API精讲&项目实战》同步在B站、今日头条、视频号及本公众号发布。其中本公众号以发布文字教程为主。
今天是大年初二,一灯在此祝愿各位朋友兔年吉祥,达成所想。
本节课主要讲解使用Range操作段落格式中的对齐和缩进。
1.ParagraphFormat属性
对齐和缩进属于段落格式,Range并不能直接操作段落格式(Paragraph(s)就可以),不过所幸的是,Range中封装了一个ParagraphFormat的属性,它是一个独立接口,代表了段落的所有格式,通过它,则能实现Range操作段落格式。
2.对齐和混合格式的坑
对齐的操作非常简单,示例如下:
from win32com.client import Dispatch
client = Dispatch('word.Application')
clinet.Visbile = 1
doc = client.Documents.Open(file_name)
# 假设打开的文档中有两端文字
rng1.Range(0,0)
rng1.MoveEnd(4,1)
rng1.ParagraphFormat.Alignment
>>>0
Alignment用来返回或设置Range对象所在段落的对齐情况,返回int,其对照关系如下:
| 常量 | 对齐 |
|---|---|
| 0 | 左对齐 |
| 1 | 居中对齐 |
| 2 | 右对齐 |
| 3 | 两端对齐 |
| 4 | 分散对齐 |
对齐的操作非常简单,但有个坑需要避开:混合格式,我们模拟以下的情形。
对齐避坑指南
加速以上文档中两个段落的对齐都不一样,当我们使用doc.Range().ParagraphFormat.Alignment来获取全文档的对齐时,会返回9999999,这是因为两个段落的对齐不一样,也就是这里所说的混合格式,这种情形不止存在于对齐中,还有字体、字号以及页面设置等资源都会有。
一般开发中,我们需要逐个资源进行处理,以避免掉进混合格式的坑。
缩进
word编程接口中的缩进和客户端中设置面板的缩进选项是一一对应的,对齐的接口如下:
| 名称 | 接口 | 说明 |
|---|---|---|
| 首行缩进/悬挂缩进 | CharacterUnitFirstLineIndent | 以字符为单位缩进 |
| FirstLineIndent | 以磅值为单位缩进 | |
| 左缩进 | CharacterUnitLeftIndent | 以字符为单位缩进 |
| LeftIndent | 以磅值为单位缩进 | |
| 右缩进 | CharacterUnitRightIndent | 以字符为单位缩进 |
| RightIndent | 以磅值为单位缩进 |
首行缩进和悬挂缩进共用接口,它们两个的操作效果是相反的,所以在客户端中缩进设置面板中,它们两个处于一个下拉框中,如下图:

文本之前对应着左缩进的接口,文本之后对应着右缩进的接口。
同时,可以留意到,客户端提供了几个缩进的单位,这些单位最后都会被转换成磅值进行保存。在word编程的接口中,仅提供了两个单位的缩进接口,如上表中,带有CharacterUnit字样的接口属于按字符为单位进行缩进,反之按磅值为单位进行缩进。
代码演示(接着上面的代码)
# 对第一个段落执行首行缩进2字符
rng1.ParagraphFormat.CharacterUnitFirstLineIndent = 2
# 等效的做法 一个字号磅值等于一个字符
rng1.ParagraphFormat.FirstLineIndent = 当前段落字号磅值 * 2
缩进避坑指南
磅值是所有缩进最终会保存的尺度单位,即无论使用字符设置还是厘米设置,最终会被计算成磅值保存到OLE对象中,这个保存的逻辑会引起一些小坑,当我们使用字符设置缩进时,系统中计算、保存磅值的同时,也会记录字符值,所以上述代码中,使用字符设置了首行缩进,我们既能通过CharacterUnitFirstLineIndent属性获取当前缩进的字符值,也能通过FirstLineIndent属性获取磅值,但反之却不行。一图胜千字,请看下图。


所以,当我们要取消缩进时:
- 如果当前使用的是磅值缩进,只需要按照磅值缩进接口赋值为0即可
- 如果当前使用的是字符缩进,则需要先设置磅值缩进为0,再设置字符缩进为0方可取消。(因为这种情况它有两个缩进值,一为磅值,二为字符值)
暂时理解不了的话,自己敲一遍代码就能明白了。
悬挂缩进
悬挂缩进和首行缩进共用接口,前者使用负数赋值,后者使用正数赋值,这非常简单,伪代码演示即可。
# 悬挂缩进2字符
rng.ParagraphFormat.CharacterUnitFirstLineIndent = -2
至于左缩进和右缩进,使用方法、坑和首行缩进一模一样,请自行测试。
ok,本课内容就到这,下节课我们继续讲解Range的其他属性方法。
有疑问,可私信也可评论区交流哈。
win32com操作word API精讲 第六集 Range(四)对齐和缩进的更多相关文章
- WKWebView API精讲(OC)
WKWebView API精讲(OC) 前言 鉴于LL同志对笔者说:“能不能写个OC版本的WKWebView的使用教程?”,还积极打赏了30RMB,笔者又怎么好意思拒绝呢,于是才有了下文. 所有看到本 ...
- win32com操作word(1):几个重要的对象(28.35)
Pywin32模块为python封装了操作windows底层API函数的功能.而win32com是Pywin32下面的一个模块,专门负责操作com组件. 由于office工具(Word.Excel等) ...
- win32com操作word(3):导入VBA常量
导入VBA常量方法:http://blog.sina.com.cn/s/blog_a73687bc0101k8x8.html 我们之前说过,win32com组件为python提供处理COM组件(.dl ...
- win32com操作word(2):常用用法
一.对象的位置关系: 1.Range属性位于(部分): Selection__Section__Cell__Paragraph__Table__Bookmark__Comment__Row__List ...
- 《修炼之道:.NET开发要点精讲》读书笔记(四)
委托的作用:1)它允许把方法作为参数,传递给其它的模块:2)它允许我们同时调用多个具有相同签名的方法:3)它允许我们异步调用任何方法. “方法签名”指方法的参数个数.参数类型以及返回值等,具有相同签名 ...
- 第三百六十二节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)基本的索引和文档CRUD操作、增、删、改、查
第三百六十二节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)基本的索引和文档CRUD操作.增.删.改.查 elasticsearch(搜索引擎)基本的索引 ...
- 第三百六十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现搜索功能
第三百六十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现搜索功能 Django实现搜索功能 1.在Django配置搜索结果页的路由映 ...
- 第三百六十八节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现搜索的自动补全功能
第三百六十八节,Python分布式爬虫打造搜索引擎Scrapy精讲—用Django实现搜索的自动补全功能 elasticsearch(搜索引擎)提供了自动补全接口 官方说明:https://www.e ...
- 第三百六十七节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)scrapy写入数据到elasticsearch中
第三百六十七节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)scrapy写入数据到elasticsearch中 前面我们讲到的elasticsearch( ...
- 第三百六十三节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的mget和bulk批量操作
第三百六十三节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的mget和bulk批量操作 注意:前面讲到的各种操作都是一次http请求操作一条数据,如果想 ...
随机推荐
- python同时识别多张人脸(运用face_recognition)
之前发的博客和网上流传的代码严格来说都只算得上是人脸检测,不能区别人脸,今天来说说真的人脸识别 篇幅所限,就举两张人脸的例子了,本程序需要安装face_recognition 下面是全部源代码: im ...
- LcdTools如何使用PX01进行EDP屏EDID比对及设置显示EDID比对结果
PX01点EDP屏在上电过程会自动读取屏EDID,那怎么进行EDID比对呢? LcdTools打开点屏工程,在上电时序函数中先用SetCmpEDID()指令设置EDID比对值,再调用CheckEDID ...
- 题解 P3395 路障
前言 没想到这是\(\sf {tgD1T1}\)难度-- 题目大意 有一个\(n\times n\) 的棋盘,有\(2n-2\) 个路障,在第\(i\) 秒会在\((x_i,y_i)\) 放置路障.求 ...
- 深度学习环境搭建常用网址、conda/pip命令行整理(pytorch、paddlepaddle等环境搭建)
前言:最近研究深度学习,安装了好多环境,记录一下,方便后续查阅. 1. Anaconda软件安装 1.1 Anaconda Anaconda是一个用于科学计算的Python发行版,支持Linux.Ma ...
- 时序数据库TDengine 详细安装+集成流程+问题解决
官方文档:https://docs.taosdata.com/get-started/package/ 点击进入 产品简介 TDengine 是一款高性能.分布式.支持 SQL 的时序数据库 (Dat ...
- JavaScrip基础学习笔记(一)
一.三元表达式 1.1 什么是三元表达式 由三元运算符组成的式子我们称为三元表达式 1.2 语法结构 条件表达式 ? 表达式1 : 表达式2 1.3 执行思路 如果表达式为结果真 则返回表达式1的值, ...
- 两种方案实现Dubbo泛化调用
Dubbo的泛化调用是一个服务A在没有服务B的依赖,包的情况下,只知道服务B的服务名:服务的接口的全限定类名和方法名,以及参数,实现服务A调用服务B. 原文链接:http://blog.qiyuan. ...
- 多点DMALL × Apache Kyuubi:构建统一SQL Proxy探索实践
伴随着国家产业升级的推进和云原生技术成熟,多点 DMALL 大数据技术也经历了从存算一体到存算分离的架构调整变迁.本文将从引入 Kyuubi 实现统一 SQL Proxy 的角度讲述这一探索实践的历程 ...
- Dijkstra 算法说明与实现
Dijkstra 算法说明与实现 作者:Grey 原文地址: 博客园:Dijkstra 算法说明与实现 CSDN:Dijkstra 算法说明与实现 问题描述 问题:给定出发点,出发点到所有点的距离之和 ...
- SQLMap入门——获取当前网站数据库的用户名称
列出当前网站使用的数据库用户 python sqlmap.py -u http://localhost/sqli-labs-master/Less-1/?id=1 --current-user