从Excel中导出图片

本文介绍了一种使用VBA宏将Excel工作表中的图片导出为硬盘上的JPG文件的方法。首先需要选择要导出的图片,然后通过创建临时图表并调整其尺寸来匹配所选图片的大小。接下来复制选定的图片并将其粘贴到该图表中,最后导出图表为指定的JPG文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文链接:http://www.vbforums.com/showthread.php?538529-Export-an-Image-from-Excel-Sheet-to-Hard-Drive

Option Explicit 
'You need to select a picture before running this code
'else it will give you error'
Sub PictureExport()
    Dim TempChart As String, Picture2Export As String
    Dim PicWidth As Long, PicHeight As Long
      
    Picture2Export = Selection.Name
      
    'Store the picture's height and width  in a variable
    With Selection
        PicHeight = .ShapeRange.Height
        PicWidth = .ShapeRange.Width
    End With
      
    'Add a temporary chart in sheet1
    Charts.Add
    ActiveChart.Location Where:=xlLocationAsObject, Name:="Sheet1"
    Selection.Border.LineStyle = 0
    TempChart = Selection.Name & " " & Split(ActiveChart.Name, " ")(2)
      
    With ActiveSheet
        'Change the dimensions of the chart to suit your need
        With .Shapes(TempChart)
            .Width = PicWidth
            .Height = PicHeight
        End With
            
        'Copy the picture
        .Shapes(Picture2Export).Copy
            
        'Paste the picture in the chart
        With ActiveChart
            .ChartArea.Select
            .Paste
        End With
            
        'Finally export the chart
        .ChartObjects(1).Chart.Export Filename:="Sample.jpg", FilterName:="jpg"
        'Destroy the chart. You may want to delete it...
        .Shapes(TempChart).Cut
      End With
End Sub


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值