开发者社区> 问答> 正文

Excel VBA在F8中工作,但不在F5模式下工作

我通读了关于同一问题的多个线程,但是它们似乎都具有不同的解决方案,因此无法将其应用于我的代码。我还在“导出”部分的所有行之间Application.Wait (Time + TimeValue("00:00:01"))以及DoEvents之间进行了代码测试。

当我使用F5运行代码时,将导出空白图片。当我使用F8逐步运行它时,将导出正确的图片。当我快速跳过F8时,它也不起作用。我试图找出哪条线不允许执行得太快,但是失败了。

Sub ExportSingleImage()
    'Plotplan Export Single Script v. 2.3

    Dim sheet, zoom_coef, area, chartobj
    Dim exportpath, prefix As String
    Dim sView, rr As String
    Dim xWs As Worksheet
    Dim leadingzeros As Boolean

    'Export Path (with trailing backslash)
    exportpath = ActiveWorkbook.Worksheets("Config").Range("B2")

    'Prefix
    prefix = ""

    'Tankstellennummern Länge
    idnumber_max = 6

    'Leading Zeros
    leadingzeros = False

    'Print Area
    rr = "B2:AI38"

    '------------------------------------------------------------------------------
    'Nothing to configure after here
    '------------------------------------------------------------------------------

    'Ask if existing files should be overwritten
    overwrite = MsgBox("Existierende Dateien überschreiben?", vbYesNoCancel)
    If overwrite = vbCancel Then
        Exit Sub
    End If

    Set xWs = ActiveWorkbook.ActiveSheet

    'Error when the sheetname is longer than the allowed max
    If Len(xWs.Name) > idnumber_max Then
        prompt = "Bezeichnung zu lang: " & xWs.Name & " (Maximal " & idnumber_max & " Stellen.)"
        MsgBox (prompt)
        Exit Sub
    End If

    'Check if export folder exists. If not, create it.
    If Dir(exportpath, vbDirectory) = "" Then
        MkDir exportpath
    End If

    'Assemble full path with filename
    If leadingzeros Then
        exportpath = exportpath & prefix & Right("000000" & xWs.Range("AJ47").Value, idnumber_max) _
            & " - " & xWs.Range("AJ43").Value & ".png"
    Else
        exportpath = exportpath & prefix & xWs.Range("AJ47").Value _
            & " - " & xWs.Range("AJ43").Value & ".png"
    End If

    'Check if file already exists or "overwrite" had been selected by the user
    If Dir(exportpath) = "" Or overwrite = vbYes Then

        ' -- EXPORT --

        'Captures current window view
        sView = ActiveWindow.View

        'Sets the current view to normal so there are no "Page X" overlays on the image
        ActiveWindow.View = xlNormalView

        'Temporarily disable screen updating
        Application.ScreenUpdating = False

        'Selection Print Area
        xWs.PageSetup.PrintArea = xWs.Range(rr).Resize(xWs.Range(rr).Rows.Count, xWs.Range(rr).Columns.Count).Address

        'Export print area as correctly scaled PNG image, courtasy of Winand
        'Lukasz: zoom_coef can be constant = 0 to 5 can work too, but save is 0 to 4

        zoom_coef = 2 '100 / sheet.Parent.Windows(1).Zoom

        Set area = xWs.Range(xWs.PageSetup.PrintArea)
        area.CopyPicture xlPrinter  'xlBitmap
        Set chartobj = xWs.ChartObjects.Add(0, 0, area.Width * zoom_coef, area.Height * zoom_coef)
        chartobj.Chart.Paste
        chartobj.Chart.Export exportpath, "png"
        chartobj.Delete

        'Returns to the previous view
        ActiveWindow.View = sView

        'Re-enables screen updating
        Application.ScreenUpdating = True

    End If
End Sub

展开
收起
几许相思几点泪 2019-12-08 22:02:29 678 0
0 条回答
写回答
取消 提交回答
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
4个迭代,从批量交...1573957773.pdf 立即下载
动态、高效,蚂蚁动态卡片的内核逻辑 立即下载
内容驱动游戏分发 立即下载