Excel VBA Macro: Check content (of clipboard?) before pasting

后端 未结 4 1300
误落风尘
误落风尘 2021-01-06 07:29

I\'ve had some serious issues with pasting data from various sources into Excel. Excel tends to try to be smart and does all kinds of silly formating. We need the data as te

相关标签:
4条回答
  • 2021-01-06 07:47

    This isn't the greatest solution, but it technically works. Just try them both.

    On Error Resume Next
    ActiveSheet.PasteSpecial Format:=Text, Link:=False, DisplayAsIcon:=False
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
    
    0 讨论(0)
  • 2021-01-06 07:52
    Sub PasteAsText() ' Assign Keyboard Shortcut: Ctrl+v
        Application.ScreenUpdating = False
        Select Case Application.CutCopyMode
            Case Is = False
                    On Error Resume Next
                    ActiveSheet.PasteSpecial Format:="Text", Link:=False, DisplayAsIcon:=False
            Case Is = xlCopy
                If Not Range(GetClipboardRange).HasFormula Then
                    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
                Else
                    ActiveSheet.Paste
                End If
            Case Is = xlCut
                ActiveSheet.Paste
        End Select
        Application.CutCopyMode = False
        Application.ScreenUpdating = True
    End Sub
    
    Function GetClipboardRange() As String
        ' Edited from http://www.ozgrid.com/forum/showthread.php?t=66773
        Dim formats    'Check to make sure clipboard contains table data
        formats = Application.ClipboardFormats
        For Each fmt In formats
            If fmt = xlClipboardFormatCSV Then
                Application.ActiveSheet.Paste Link:=True  'Paste link
    
                Dim addr1, addr2 As String 'Parse formulas from selection
    
                addr1 = Application.Substitute(Selection.Cells(1, 1).Formula, "=", "")
                addr2 = Application.Substitute(Selection.Cells(Selection.Rows.Count, Selection.Columns.Count).Formula, "=", "")
    
                GetClipboardRange = addr1 & IIf(addr1 <> addr2, ":" & addr2, "")
                Exit For
            End If
        Next
    End Function
    
    0 讨论(0)
  • 2021-01-06 07:56

    Have you considered making the cells in the target sheet equal to Text? When they're General, Excel does it's best-guess at what you expect to see.

    On the other hand if you really want to implement Paste Special...

    There is no "Paste" event you can catch - you have catch every place that a paste could occur.

    For example, you can capture the CTRL-V keypress if you issue the following code when the workbook starts up (Workbook_Open):

    Application.OnKey "^v", "DoMyPaste"
    

    This will call your function instead of the Excel paste function. Put something like this in a module:

    Public Sub DoMyPaste()
        If Selection.[is marked cell] Then
            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
        Else
            ActiveSheet.PasteSpecial Format:="Text", Link:=False, DisplayAsIcon _
            := False
        End If
    End Sub
    

    I have not tested this, this is more of a rough sketch. Do note that Selection could be more than one cell, so your "check for a marked cell" needs to check the whole range in some way.

    This is just the tip of the iceberg though. If you want to a full solution, you should check out this article, which is the OCD version of catching all Paste calls:

    http://www.jkp-ads.com/Articles/CatchPaste.asp
    
    0 讨论(0)
  • 2021-01-06 08:00

    For clipboard access/manipulation, you'll want to add a reference to the Microsoft Forms 2.0 library in Project->References. You can then use the MSForms.DataObject class that has (among others) a GetFormat method to check whether the clipboard has a particular type of data.

    This is a pretty good intro to clipboard handling using DataObject.

    0 讨论(0)
提交回复
热议问题