word表格首行缩进
今天朋友给我发来视频,问我excel表格里边的文字怎么排版,不知道是不是版本的原因,调整很是费劲。我一边给她看一边打开自己的电脑,选中表格后鼠标右键的设置单元格格式里边调整了好几次也不是很理想。朋友的...
2024.11.23《VBA信息获取与处理》教程(10178984)是我推出第六套教程,目前已经是第一版修订了。这套教程定位于最高级,是学完初级,中级后的教程。这部教程给大家讲解的内容有:跨应用程序信息获得、随机信息的利用、电子邮件的发送、VBA互联网数据抓取、VBA延时操作,剪贴板应用、Split函数扩展、工作表信息与其他应用交互,FSO对象的利用、工作表及文件夹信息的获取、图形信息的获取以及定制工作表信息函数等等内容。程序文件通过32位和64位两种OFFICE系统测试。是非常抽象的,更具研究的价值。
教程共两册,二十个专题。今日分享内容是:第四节(2):修改WORD中表格数据的方案
【分享成果,随喜正能量】人生像一只皮箱,需要用的时候提起,不用的时就把它放下,应放下的时候,却不放下,就像拖着沉重的行李,无法自在。人生的岁月有限,认错、尊重、包容才能让人接受,放下才自在啊。
第四节 在EXCEL中打开及修改WORD文件在上面的专题中,我们讲了如何在WORD中打开EXCEL。那么同理,如何在EXCEL中打开WORD呢?在这讲中我给出专题的讲解,这个讲解中我们将利用CreateObject函数和GetObject 函数分别建立一个引用及获取已经打开的WORD文件信息。这讲的内容为了增加实用性,我在程序中还给出了如何向WORD的表格(非嵌套)中添加数据,这个数据来源于EXCEL。
2 主程序及修改WORD中的表格数据的方案在中主程序中我们将利用WordIsOpen函数对我们需要判断的文件进行判断,如果没有打开,那么执行打开操作,再进行修改;如果已经打开,那么执行修改操作。
代码如下:
Sub MYNZB()
Dim RR As Boolean
Dim myWdA As Object
Dim MyDocument As Object
RR = WordIsOpen(ThisWorkbook.Path & "\001 在WORD中激活EXCEL.docm")
If Not RR Then ‘创建Word对象
Set myWdA = CreateObject("Word.Application")
myWdA.Visible = True ‘打开指定文档
Set MyDocument = myWdA.Documents.Open(ThisWorkbook.Path & "\001 在WORD中激活EXCEL.docm")
‘获取当前Excel的SHEET2的单元格C2数据
mystr = ThisWorkbook.Sheets(2).Cells(2, 3).Value
‘将取得得值设定到Word表格的1行2列中
MyDocument.Tables(1).Cell(2, 3).Range.Text = mystr
MyDocument.Save
Set myWdA = Nothing
Set MyDocument = Nothing
Else
Set myWdA = GetObject(, "WORD.Application")
For Each doc In myWdA.Documents
UU = UCase(doc.FullName)
If doc.FullName = ThisWorkbook.Path & "\001 在WORD中激活EXCEL.docm" Then
mystr = ThisWorkbook.Sheets(2).Cells(2, 3).Value
‘将取得得值设定到Word表格的1行2列中
doc.Tables(1).Cell(2, 3).Range.Text = mystr
doc.Save
Set doc = Nothing
Exit For
End If
Next
Set myWdA = Nothing
End If
End Sub
代码截图:
代码解读:上述代码先利用WordIsOpen函数判断"001 在WORD中激活EXCEL.docm"是否已经打开,如果没有打开,那么利用CreateObject函数建立引用,然后打开这个文件,打开后修正文件文件,如果已经打开了文件,那么首先定位到打开的文件,然后在修正。下面看代码的重点讲解:
① If Not RR Then ‘创建Word对象
Set myWdA = CreateObject("Word.Application")
myWdA.Visible = True ‘打开指定文档
Set MyDocument = myWdA.Documents.Open(ThisWorkbook.Path & "\001 在WORD中激活EXCEL.docm")
‘获取当前Excel的SHEET2的单元格C2数据
mystr = ThisWorkbook.Sheets(2).Cells(2, 3).Value
‘将取得得值设定到Word表格的1行2列中
MyDocument.Tables(1).Cell(2, 3).Range.Text = mystr
MyDocument.Save
Set myWdA = Nothing
Set MyDocument = Nothing
上述代码是打开文件及修正文件的代码。
② Set myWdA = GetObject(, "WORD.Application")
For Each doc In myWdA.Documents
UU = UCase(doc.FullName)
If doc.FullName = ThisWorkbook.Path & "\001 在WORD中激活EXCEL.docm" Then
mystr = ThisWorkbook.Sheets(2).Cells(2, 3).Value
‘将取得的值设定到Word表格的1行2列中
doc.Tables(1).Cell(2, 3).Range.Text = mystr
doc.Save
Set doc = Nothing
Exit For
End If
Next
Set myWdA = Nothing
上述代码是当文件已经打开,定位所给出的文件,然后修订文件的代码。
③ 上述文件修订的代码,我给出的比较简单,大家在实际利用的时候可以发挥使用。
本节知识点回向:如何利用CreateObject函数和GetObject 函数来判断一个给定的文件是否打开?当已经得到文件已经打开时如何定位到这个文件?以上两个问题就是本节要讲解的主要问题,其中的代码完全可以用作通用代码来对待。
备注:本节代码参考文件“001 工作表.xlsm”
我20多年的VBA实践经验,全部浓缩在下面的各个教程中,教程学习顺序:
今天朋友给我发来视频,问我excel表格里边的文字怎么排版,不知道是不是版本的原因,调整很是费劲。我一边给她看一边打开自己的电脑,选中表格后鼠标右键的设置单元格格式里边调整了好几次也不是很理想。朋友的...
2024.11.23在Word文档中,表格历来是令人头疼的事情,不仅仅是编辑起来不像Excel那样方便,在后期调整上也很难达到我们想要的效果,比如内部单元格的框线对齐问题,就难到了一大批小白们,今天就让我们一起来学习一下...
2024.11.24很多人都知道,在Excel表格中用“ROW”函数可连续添加序号,并且在删除某个序号后,所有序号还能够连续出现,但如果是在Word表格中,又如何实现上述效果呢?其实,在Word表格中用好“项目编号”,就...
2024.11.22Word制作表格时,有时需要拆分单元格,那么怎么拆分呢?以最常用的极速办公speedoffice为例。1、首先,打开带表格的Word文档,光标定位到要拆分的单元格上;2、然后,鼠标右键,在右键菜单中,...
2024.11.20大家好!今天和大家分享一下表格中数据转置的案例,本篇教程案例来源于小伙伴日常答疑取材。下图是同学希望将基础数据转为效果数据模拟的图示,值得夸赞的是同学动手模拟了效果图,这样让答疑的人能清晰的知道最终想...
2024.11.22