Excel单元格中自适应填充多图

news/2024/11/18 19:36:23/

实例需求:在Excel插入图片时,由于图片尺寸各不相同,如果希望多个图片填充>图片填充指定单元格,依靠用户手工调整,不仅费时费力,而且很难实现完全填充。如下图中的产品图册,有三个图片,如下图所示。

在这里插入<a class=图片描述" />

在不改变C列宽度的情况下,需要将三个图片调整为相同高度,并且填满单元格(可以修改行高)。

在这里插入<a class=图片描述" />

Sub Demo()Dim rngCell As Range, oShp As ShapeDim wAll As Double, r As Double, iLeft As DoubleSet rngCell = Range("C2")For Each oShp In Sheet1.ShapesoShp.LockAspectRatio = msoCTrueoShp.Height = 100wAll = wAll + oShp.Width + 1Nextr = rngCell.Width / (wAll + 1)iLeft = rngCell.Left + 1For Each oShp In Sheet1.ShapesoShp.Height = 100 * roShp.Top = rngCell.Top + 1oShp.Left = iLeftiLeft = iLeft + oShp.Width + 1NextrngCell.RowHeight = Sheet1.Shapes(1).Height + 2
End Sub

【代码解析】
第5行代码指定图片填充>图片填充单元格。
第6~10行代码循环遍历工作表Sheet1中的图片
第7行代码锁定图片的纵横比,避免调整图片尺寸导致图片变形。
第8行代码统一图片高度。
第9行代码统计图片的累计宽度,此处加一作为相邻图片之间的间隔。
第11行代码计算缩放比例。
第12行代码计算图片的水平偏移位置,第一图片的偏移量于单元格的Left属性相同,即对齐被填充单元格的左侧。此处增加偏移量为1,是为了避免图片覆盖单元格边框线。
第13~18行代码循环遍历工作表Sheet1中的图片,设置图片位置和尺寸。
第14行代码修改图片高度,由于锁定了纵横比,因此图片的宽度也会按同比例变化。
第15行代码设置图片Top属性于被填充单元格相同,即对齐被填充单元格顶部。
第16行代码调整图表位置。
第17行代码累加当前图片宽度,计算下一个图片位置。
第19行代码修改被填充单元格的高度,以适配图片高度。


http://www.ppmy.cn/news/1548067.html

相关文章

nodejs入门(1):nodejs的前后端分离

一、引言 我关注nodejs还是从前几年做了的一个电力大数据展示系统开始的&#xff0c;当然&#xff0c;我肯定是很多年的计算机基础的&#xff0c;万变不离其宗。 现在web网站都流行所谓的前后端结构&#xff0c;不知不觉我也开始受到这个影响&#xff0c;以前都是前端直接操作…

[C/C++] 定位新表达式 placement new

在C中&#xff0c;表达式 new (ptr) T(); 展示了一种特殊的内存分配和对象构造方式&#xff0c;这被称为定位新表达式&#xff08;placement new&#xff09;。 通常&#xff0c;当我们使用 new 关键字时&#xff0c;它会在堆上动态分配内存&#xff0c;并调用相应的构造函数来…

【ES6】ES6中,如何实现桥接模式?

桥接模式是一种设计模式&#xff0c;它旨在将抽象部分与它的实现部分分离&#xff0c;使它们可以独立变化。在JavaScript&#xff08;特别是使用ES6特性&#xff09;中&#xff0c;我们可以利用类&#xff08;class&#xff09;、继承&#xff08;extends&#xff09;、模块化等…

微信小程序之轮播图

效果图 实现 <swiper class"banner" indicator-dots"true" indicator-color"rgba(255,255,255,1)" indicator-active-color"#ff0000" autoplay"true" interval"100" circular"true"><swi…

[AI] 从“进取号”到现代 NLP:机器语言理解的挑战与未来

在《星际迷航》系列中,“进取号”上的计算机以其即时、准确的回应成为人机交互的“北极星”,被视为完美智能助手的理想形象。这种理想不仅吸引了科幻迷,也激励了人工智能研究者。机器能否像“进取号”的计算机一样理解并回应复杂问题,仍是人工智能(AI)和自然语言处理(NL…

python核心语法

目录 核⼼语法第⼀节 变量0.变量名规则1.下⾯这些都是不合法的变量名2.关键字3.变量赋值4.变量的销毁 第⼆节 数据类型0.数值1.字符串2.布尔值(boolean, bool)3.空值 None 核⼼语法 第⼀节 变量 变量的定义变量就是可变的量&#xff0c;对于⼀些有可能会经常变化的数据&#…

用 Python 从零开始创建神经网络(五):损失函数(Loss Functions)计算网络误差

用损失函数&#xff08;Loss Functions&#xff09;计算网络误差 引言1. 分类交叉熵损失&#xff08;Categorical Cross-Entropy Loss&#xff09;2. 分类交叉熵损失类&#xff08;The Categorical Cross-Entropy Loss Class&#xff09;展示到目前为止的所有代码3. 准确率计算…

rhcsa笔记二

普通文件的创建 touch命令的使用 touch 文件名 &#xff08;文件路径&#xff09; linux不是用后缀区分文件类型的&#xff0c;而是用ll出现的第一个字符区分文件类型的 -&#xff1a;普通文件 d:目录文件 [rootserver ~]# stat /etc/hostname 文件&#xff1a;/etc/hos…