本文记录 Office Open XML (OOXML) 的测量单位

在 Office Open XML 默认单位是 dxa 也就是像素点的 20 倍,如 ISO 216 A4 (210x297mm ~ 8.3×11.7in) 的大小可以使用下面代码表示

在页面大小 Page width Page height 和边距 margin 和缩进 tabs 使用

<w:pgSz w:w="11906" w:h="16838"/>

单位计算可以使用下面公式

像素 Points = dxa/20 
英寸 Inches = Points/72
厘米 Centimeters = Inches*2.54

在 OpenXML 因为 dxa 是像素点的 20 倍,所以也叫二十分之一点,另外这里说的像素点是 Point 而不是像素 Pixel 哦

缩写如下

  • Points:pt
  • Inches:in
  • Centimeters:cm

以 A4 为例

Width = 11906 dxa = 595.3 point = 8.27 in = 21 cm

Half-points

用来表示字体大小的半点,一个点等于两个半点,如表示 12pt 可以这样写

// run properties
<w:rPr>
  // 24 = 12pt
  <w:sz w:val="24"/>
</w:rPr>

Fiftieths of a Percent

表示百分比相对值,用于表示表格的宽度和相对宽度,他的值和百分比换算如下

n/100 * 5000

如百分之50可以表示为 50/100 * 5000 pct 的大小,如表格的宽度是百分之50宽度

<w:tbl>
    <w:tblPr>
      <!-- 表格宽度是百分之50宽度 -->
      <w:tblW w:w="2500" w:type="pct"/>
    </w:tblPr>
    <w:tblGrid/>
    <w:tr>
        <w:tc>
            <w:p>
                <w:r>
                    <w:t>Hello, World!</w:t>
                </w:r>
            </w:p>
        </w:tc>
    </w:tr>
</w:tbl>

English Metric Unit

这也是最常用的单位,使用 EMUs (English Metric Unit) 用来表示图片和其他元素的宽度,换算如下

1 in = 914400 EMUs
1 cm = 360000 EMUs

如用于 w:drawing 绘制,表示绘制画布的宽度 <wp:extent cx="1530350" cy="2142490"/> 用这么大的数是可以提高精度和性能,不需要通过浮点计算

开源库

我开源了 dotnetCampus.OpenXMLUnitConverter 包含了本文的转换方法

工具获取方法是通过以下命令安装 dotnet 工具

dotnet tool update -g dotnetCampus.OfficeDocumentZipper

启动工具方法是在命令行输入下面代码

OfficeDocumentZipper

另外,在项目使用,可以通过 NuGet 安装 dotnetCampus.OpenXMLUnitConverter 这个库

dotnet add package dotnetCampus.OpenXMLUnitConverter

这个库同时包含使用 SourceYard 打包的源代码 NuGet 包,可以使用下面代码安装

dotnet add package dotnetCampus.OpenXMLUnitConverter.Source

也可以在 csproj 添加下面代码

<PackageReference Include="dotnetCampus.OpenXMLUnitConverter.Source" Version="1.0.2-alpah01">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>

更多请看 Office 使用 OpenXML SDK 解析文档博客目录


本文会经常更新,请阅读原文: https://dotnet-campus.github.io//post/Office-Open-XML-%E7%9A%84%E6%B5%8B%E9%87%8F%E5%8D%95%E4%BD%8D.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

知识共享许可协议 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 lindexi (包含链接: https://dotnet-campus.github.io/ ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系