Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何从同一模板为不同的输入/场景生成多个图表

如何从同一模板为不同的输入/场景生成多个图表
EN

Stack Overflow用户
提问于 2019-01-14 23:40:13
回答 2查看 79关注 0票数 0

我正在使用Excel,并且有一些基本的VBA /宏知识。我有一个相当大的数据集,每周都会更新。在此基础上,我使用一系列Index/match为特定产品生成一个40列(日期)乘4行(时间序列数据)的表。我有15-20种不同的产品,它们经常变化。然后使用这个4x40表格来生成图表。使用这种方法,我可以用下拉框选择产品(数据验证),我的索引/匹配将正确的数据拉到4x40表中,然后显示该产品的图表。但我希望有一个宏,它可以为产品1生成图表,将其作为图像复制并粘贴到word文档中,然后对产品2和3执行相同的操作,依此类推,然后将单词文档保存为pdf以供分发。

一种选择是创建15-20个4x40表和15-20个图表,然后复制/粘贴所有这些表,但随着产品的更改,如果需要更改格式,这将成为一场噩梦。

EN

回答 2

Stack Overflow用户

发布于 2019-01-15 00:51:52

如果没有看到你确切的工作表,很难给出一段确切的代码。然而,我最近做了一个与此类似的要求的工作簿。

作为答案的大纲,您可以考虑使用循环遍历您的15 - 20个产品列表,将每个产品放入您当前进行数据验证的单元格中(确保您首先删除了任何验证),这将更新索引匹配以及您的图表。在该循环中,您可以包含一些代码,以便在转到下一个产品之前将工作表保存为pdf (或者将图表放在单独的工作表中并显式引用它)。

例如,如果你的验证是在单元格A1工作表“表”中,而你的产品列表是A2:A20工作表" products“,这样的东西会让你得到一些好处;

代码语言:javascript
运行
AI代码解释
复制
Sub save_charts()

Dim i As Long
Dim path As String
Dim product_name As String
Dim ws_name As String
Dim file_name As String

i = 2
path = Application.DefaultFilePath

Do Until Worksheets("Products").Cells(i, 1).Value = ""

If Worksheets("Products").Cells(i, 1).Value <> "" Then
product_name = Worksheets("Table").Cells(1, 1).Value
ws_name = product_name & " Chart"
file_name = path & "\" & ws_name
Worksheets("Table").Cells(1, 1).Value = Worksheets("Products").Cells(i, 1).Value
    ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, Filename:= _
        file_name, Quality:=xlQualityStandard, _
        IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:= _
        True

End If

i = i + 1

Loop

End Sub

我知道你提到在导出为pdf之前将其复制到word中?这是一项要求吗?因为此代码仅使用Excel的本机导出到pdf功能。

我希望这能帮到你。

干杯。

票数 0
EN

Stack Overflow用户

发布于 2019-01-15 19:52:03

一种替代方案,将自动生成所有20个图表与每次刷新0 vba将是做以下步骤1次: 1.创建一个透视表和透视表图表,你需要为给定的产品,例如过滤它在一个单一的产品代码,创建基本图表,现在推迟格式化。此数据透视表的源数据需要包括所有20个产品的数据

  1. 在步骤1的源数据中,添加另一个名为FilterID的列,并按公式设置此列,以便1=第一个产品的数据;2,第二个;3,依此类推。
  2. 返回步骤1透视表并添加FilterID作为透视筛选器,将其设置为1,以便只有第一个产品出现在图表上
  3. 设置图表的格式现在复制包含数据透视表和数据透视表的工作表
  4. FilterID on each

<

  1. >G211>

此时,您唯一需要的vba是循环浏览每个包含有效图表的工作表,并保存为pdf

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54190797

复制
相关文章
matlab插值函数的作用,matlab 插值函数[通俗易懂]
MATLAB中的插值函数为interp1,其调用格式为: yi= interp1(x,y,xi,’method’)
全栈程序员站长
2022/09/05
1.4K0
matlab fprintf函数_matlab绝对值函数
按指定的格式将变量的值输出到屏幕或指定文件,fid为文件句柄,若缺省,则输出到屏幕
全栈程序员站长
2022/11/02
1K0
matlab fprintf函数_matlab绝对值函数
matlab 稀疏矩阵 乘法,Matlab 矩阵运算[通俗易懂]
说明:这一段时间用Matlab做了LDPC码的性能仿真,过程中涉及了大量的矩阵运算,本文记录了Matlab中矩阵的相关知识,特别的说明了稀疏矩阵和有限域中的矩阵。Matlab的运算是在矩阵意义下进行的,这里所提到的是狭义上的矩阵,即通常意义上的矩阵。
全栈程序员站长
2022/09/12
3.1K0
matlab的fprintf语句_matlab绝对值函数
2、用法说明: fprintf(fid, format, variables); 按指定的格式将变量的值输出到屏幕或指定文件;
全栈程序员站长
2022/11/02
1K0
【MATLAB】数据类型 ( 矩阵 | 随机数函数 | 生成矩阵 )
作用 : 生成 标准正态分布的 伪随机数 ; 标准正态分布指的是均值 0 , 方差 1 ;
韩曙亮
2023/03/29
9240
【MATLAB】数据类型 ( 矩阵 | 随机数函数 | 生成矩阵 )
matlab输出矩阵格式_matlab中uint8函数用法
1、uint8与double double函数只是将读入图像的uint8数据转换为double类型,一般不使用;常用的是im2double函数,将 uint8图像转为double类型,范围为0-1,如果是255的图像,那么255转为1,0还是0,中间的做相应改变。 MATLAB中读入图像的数据类型是uint8,而在矩阵中使用的数据类型是double。因此 I2=im2double(I1) :把图像数组I1转换成double精度类型;如果不转换,在对uint8进行加减时会产生 溢出。默认情况下,matlab将图象中的数据存储为double型,即64位浮点数;matlab还支持无符号整型 (uint8和uint16);uint型的优势在于节省空间,涉及运算时要转换成double型。 im2double():将图象数组转换成double精度类型 im2uint8():将图象数组转换成unit8类型 im2uint16():将图象数组转换成unit16类型 2、uint8和im2uint8 在数据类型转换时候uint8和im2uint8的区别,uint8的操作仅仅是将一个double类型的小数点后面的部 分去掉;但是im2uint8是将输入中所有小于0的数设置为0,而将输入中所有大于1的数值设置为255,再将所 有其他值乘以255。 图像数据在计算前需要转换为double,以保证精度;很多矩阵数据也都是double的。要想显示其,必须先 转换为图像的标准数据格式。如果转换前的数据符合图像数据标准(比如如果是double则要位于0~1之间) ,那么可以直接使用im2uint8。如果转换前的数据分布不合规律,则使用uint8,将其自动切割至0~255( 超过255的按255)。最好使用mat2gray,将一个矩阵转化为灰度图像的数据格式(double) 3、double类型图像的显示 图像数据在进行计算前要转化为double类型的,这样可以保证图像数据运算的精度。很多矩阵的很多矩 阵数据也都是double的,要想显示其,必须先转换为图像的标准数据格式。如果直接运行imshow(I),我们会 发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0~1范围内,即大于1时都 是显示为白色,而imshow显示uint8型时是0~255范围。而经过运算的范围在0-255之间的double型数据就被 不正常得显示为白色图像了。具体方法有: imshow(I/256); ———-将图像矩阵转化到0-1之间 imshow(I,[]); ———-自动调整数据的范围以便于显示 (注意这里,必须是灰度图,否 则不行) imshow(uint8(I)); imshow(mat2gray(I)); 上面的mat2gray是将最终获得的矩阵转化为灰度图像。常用的为: A = im2uint8(mat2gray(result)) 这样就将result矩阵转化为uint8类型的图像。
全栈程序员站长
2022/09/30
2.8K0
MATLAB插值函数interp1
插值法又称“内插法”,是利用函数f (x)在某区间中已知的若干点的函数值,作出适当的特定函数,在区间的其他点上用这特定函数的值作为函数f (x)的近似值,这种方法称为插值法。如果这特定函数是多项式,就称它为插值多项式。
全栈程序员站长
2022/07/01
6550
MATLAB插值函数interp1
矩阵组合matlab,matlab中矩阵的所有组合[通俗易懂]
X = perms(1:N); % # Permuations of column indices
全栈程序员站长
2022/08/01
1.4K0
MATLAB 矩阵分块函数 mat2cell 及 cellfun 函数
该文介绍了MATLAB中矩阵分块函数和cellfun函数在项目中的应用。首先介绍了mat2cell函数的用法,该函数可以将矩阵划分成不同的块,并可以指定每个块的维度。然后介绍了cellfun函数的用法,该函数可以对每个块进行相同的操作,例如求和、求均值等。最后通过一个例子说明了如何使用mat2cell和cellfun函数,将一个10*5的矩阵划分成不同的块,并求出每个块的所有元素之和。
Alan Lee
2018/01/02
4.5K0
MATLAB 矩阵分块函数 mat2cell 及 cellfun 函数
【MATLAB】矩阵操作 ( 矩阵构造 | 矩阵运算 )
设置一个已经给定的矩阵的行列重复次数 , 根据给定的矩阵 , 进行指定的重复 , 生成新矩阵 ;
韩曙亮
2023/03/29
1.3K0
【MATLAB】矩阵操作 ( 矩阵构造 | 矩阵运算 )
MATLAB矩阵运算
MATLAB以矩阵作为数据操作的基本单位,这使得矩阵运算变得非常简捷、方便、高效。矩阵是由m×n个数av (i=1,2,…,m; j = 1,2,…,n)排成的m行n列数表,记成:
全栈程序员站长
2022/09/12
1.2K0
MATLAB矩阵运算
matlab矩阵拼接
3 4 3 4]
全栈程序员站长
2022/09/12
1.9K0
MATLAB矩阵生成
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/153010.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/12
8290
matlab 矩阵除法
Matlab提供了两种除法运算:左除(/)和右除(/)。 一般情况下,x=a/b是方程a*x =b的解,而x=b/a是方程x*a=b的解。 例:a=[1 2 3; 4 2 6; 7 4 9] b=[4; 1; 2]; x=a/b 则显示:x= -1.5000 2.0000 0.5000 如果a为非奇异矩阵,则a/b和b/a可通过a的逆矩阵与b阵得到: a/b = inv(a)*b b/a = b*inv(a)
全栈程序员站长
2022/09/07
1.6K0
Matlab矩阵大全
(1)将二维矩阵A转化成一维矩阵(列向量):Matlab 默认将其转化成列向量,需要行向量转置即可。
全栈程序员站长
2022/09/12
1.2K0
Matlab矩阵大全
如何在matlab矩阵中随机生成圆【含源代码】
言归正传,巴山在浏览知乎时邀请我回答上图所示的问题,所幸就点进去看了一眼,并给了解题思路。
巴山学长
2021/03/30
2.1K0
如何在matlab矩阵中随机生成圆【含源代码】
字符串矩阵 matlab(matlab 字符串矩阵)
这里字符串矩阵(或者有更标准的名称?)是指一个矩阵中的每个元素为长短不一的字符串,如:
全栈程序员站长
2022/08/01
3.7K0
MATLAB(2)–MATLAB矩阵的表示
利用直接输入法建立矩阵:将矩阵的元素用中括号括起来,按矩阵的顺序输入各元素,同一行的各元素之间用逗号或者空格分隔,不同的元素之间用分号分隔。
全栈程序员站长
2022/09/12
1.2K0
MATLAB(2)–MATLAB矩阵的表示
matlab矩阵求逆矩阵非方阵_matlab验证逆矩阵出问题
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168305.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/20
7470
matlab矩阵求逆矩阵非方阵_matlab验证逆矩阵出问题
如何在矩阵的行上显示“其他”【2】
这个显示结果虽然达到了基础的目的,但并不是很理想。很明显,我们想的是让others在最后一行:
陈学谦
2021/11/15
1.7K0

相似问题

如何外推旋转矩阵值?

16

外推热矩阵中的封顶值

112

Matlab外推符号翻转

12

Matlab interp2外推

23

如何在Matlab中指定矩阵的子矩阵外?

20
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档