/ Forside / Teknologi / Udvikling / VB/Basic / Nyhedsindlæg
Login
Glemt dit kodeord?
Brugernavn

Kodeord


Reklame
Top 10 brugere
VB/Basic
#NavnPoint
berpox 2425
pete 1435
CADmageren 1251
gibson 1230
Phylock 887
gandalf 836
AntonV 790
strarup 750
Benjamin... 700
10  tom.kise 610
Sende værdi til Clipboad
Fra : Peter


Dato : 27-09-09 15:04

Hej Gruppe

Jeg skal bruge noget hjælp til at sende en string til clipboard, fra
access til en dialogboks i word hvor jeg vil paste værdien ind.

Jeg har ligget på forskellige løsninger men er ikke sikker på at jeg
kan bruge dem.

Hilsen

Peter

 
 
Per (27-09-2009)
Kommentar
Fra : Per


Dato : 27-09-09 22:26

Peter < pb-consult@get2net.dk > skrev følgende:

> Hej Gruppe
>
> Jeg skal bruge noget hjælp til at sende en string til clipboard, fra
> access til en dialogboks i word hvor jeg vil paste værdien ind.
>
> Jeg har ligget på forskellige løsninger men er ikke sikker på at jeg
> kan bruge dem.
>
> Hilsen
>
> Peter
>

Hej Peter,

Kopier nedennævnte kode til et modul:



Option Explicit

'********* Code Start ************
' This code was originally written by Terry Kreft.
' It is not to be altered or distributed,
' except as part of an application.
' You are free to use it in any application,
' provided the copyright notice is left unchanged.
'
' Code Courtesy of
' Terry Kreft
'

Public Const GHND = &H42
Public Const CF_TEXT = 1
Private Const CF_ANSIONLY = &H400&
Private Const CF_APPLY = &H200&
Private Const CF_BITMAP = 2
Private Const CF_DIB = 8
Private Const CF_DIF = 5
Private Const CF_DSPBITMAP = &H82
Private Const CF_DSPENHMETAFILE = &H8E
Private Const CF_DSPMETAFILEPICT = &H83
Private Const CF_DSPTEXT = &H81
Private Const CF_EFFECTS = &H100&
Private Const CF_ENABLEHOOK = &H8&
Private Const CF_ENABLETEMPLATE = &H10&
Private Const CF_ENABLETEMPLATEHANDLE = &H20&
Private Const CF_ENHMETAFILE = 14
Private Const CF_FIXEDPITCHONLY = &H4000&
Private Const CF_FORCEFONTEXIST = &H10000
Private Const CF_GDIOBJFIRST = &H300
Private Const CF_GDIOBJLAST = &H3FF
Private Const CF_HDROP = 15
Private Const CF_INITTOLOGFONTSTRUCT = &H40&
Private Const CF_LIMITSIZE = &H2000&
Private Const CF_LOCALE = 16
Private Const CF_MAX = 17
Private Const CF_METAFILEPICT = 3
Private Const CF_NOFACESEL = &H80000
Private Const CF_NOSCRIPTSEL = &H800000
Private Const CF_NOSIMULATIONS = &H1000&
Private Const CF_NOSIZESEL = &H200000
Private Const CF_NOSTYLESEL = &H100000
Private Const CF_NOVECTORFONTS = &H800&
Private Const CF_NOOEMFONTS = CF_NOVECTORFONTS
Private Const CF_NOVERTFONTS = &H1000000
Private Const CF_OEMTEXT = 7
Private Const CF_OWNERDISPLAY = &H80
Private Const CF_PALETTE = 9
Private Const CF_PENDATA = 10
Private Const CF_PRINTERFONTS = &H2
Private Const CF_PRIVATEFIRST = &H200
Private Const CF_PRIVATELAST = &H2FF
Private Const CF_RIFF = 11
Private Const CF_SCALABLEONLY = &H20000
Private Const CF_SCREENFONTS = &H1
Private Const CF_BOTH = (CF_SCREENFONTS Or CF_PRINTERFONTS)
Private Const CF_SCRIPTSONLY = CF_ANSIONLY
Private Const CF_SELECTSCRIPT = &H400000
Private Const CF_SHOWHELP = &H4&
Private Const CF_SYLK = 4
Private Const CF_TIFF = 6
Private Const CF_TTONLY = &H40000
Private Const CF_UNICODETEXT = 13
Private Const CF_USESTYLE = &H80&
Private Const CF_WAVE = 12
Private Const CF_WYSIWYG = &H8000


Private Declare Function GlobalAlloc Lib "kernel32" (ByVal wFlags&,
ByVal _
dwBytes As Long) As Long
Private Declare Function GlobalLock Lib "kernel32" (ByVal hMem As Long)
_
As Long
Private Declare Function GlobalSize Lib "kernel32" (ByVal hMem As Long)
_
As Long
Private Declare Function lstrcpy Lib "kernel32" (ByVal lpString1 As Any,
_
ByVal lpString2 As Any) As Long
Private Declare Function lstrlen Lib "kernel32" Alias "lstrlenA" _
(ByVal lpString As String) As Long

Private Declare Function GlobalUnlock Lib "kernel32" (ByVal hMem As
Long) _
As Long

Private Declare Function OpenClipboard Lib "user32" (ByVal Hwnd As Long)
_
As Long
Private Declare Function CloseClipboard Lib "user32" () As Long
Private Declare Function GetClipboardData Lib "user32" (ByVal wFormat As
_
Long) As Long
Private Declare Function EmptyClipboard Lib "user32" () As Long
Private Declare Function SetClipboardData Lib "user32" (ByVal wFormat _
As Long, ByVal hMem As Long) As Long

Function ClipBoard_SetText(strCopyString As String) As Boolean
Dim hGlobalMemory As Long
Dim lpGlobalMemory As Long
Dim hClipMemory As Long

' Allocate moveable global memory.
'-------------------------------------------
hGlobalMemory = GlobalAlloc(GHND, Len(strCopyString) + 1)

' Lock the block to get a far pointer
' to this memory.
lpGlobalMemory = GlobalLock(hGlobalMemory)

' Copy the string to this global memory.
lpGlobalMemory = lstrcpy(lpGlobalMemory, strCopyString)

' Unlock the memory and then copy to the clipboard
If GlobalUnlock(hGlobalMemory) = 0 Then
If OpenClipboard(0&) <> 0 Then
Call EmptyClipboard
hClipMemory = SetClipboardData(CF_TEXT, hGlobalMemory)
ClipBoard_SetText = CBool(CloseClipboard)
End If
End If
End Function

Function ClipBoard_GetText() As String
Dim hClipMemory As Long
Dim lpClipMemory As Long
Dim strCBText As String
Dim retVal As Long
Dim lngSize As Long
If OpenClipboard(0&) <> 0 Then
' Obtain the handle to the global memory
' block that is referencing the text.
hClipMemory = GetClipboardData(CF_TEXT)
If hClipMemory <> 0 Then
' Lock Clipboard memory so we can reference
' the actual data string.
lpClipMemory = GlobalLock(hClipMemory)
If lpClipMemory <> 0 Then
lngSize = GlobalSize(lpClipMemory)
strCBText = Space$(lngSize)
retVal = lstrcpy(strCBText, lpClipMemory)
retVal = GlobalUnlock(hClipMemory)
' Peel off the null terminating character.
strCBText = Left(strCBText, InStr(1, strCBText, Chr$(0), 0) - 1)
Else
MsgBox "Could not lock memory to copy string from."
End If
End If
Call CloseClipboard
End If
ClipBoard_GetText = strCBText
End Function

'********* Code End ************

Her får du så muligheden for både at indlæse og udlæse data til og fra
Clipboard'et.

PS ! Håber du har ligget godt...



--
Med venlig hilsen

Per

Peter (28-09-2009)
Kommentar
Fra : Peter


Dato : 28-09-09 01:11

On 27 Sep., 23:26, Per <Jens...@Hotmail.com> wrote:
> Peter < pb-cons...@get2net.dk > skrev følgende:
>
> > Hej Gruppe
>
> > Jeg skal bruge noget hjælp til at sende en string til clipboard, fra
> > access til en dialogboks i word hvor jeg vil paste værdien ind.
>
> > Jeg har ligget på forskellige løsninger men er ikke sikker på at jeg
> > kan bruge dem.
>
> > Hilsen
>
> > Peter
>
> Hej Peter,
>
> Kopier nedennævnte kode til et modul:
>
> Option Explicit
>
> '*********  Code Start  ************
> ' This code was originally written by Terry Kreft.
> ' It is not to be altered or distributed,
> ' except as part of an application.
> ' You are free to use it in any application,
> ' provided the copyright notice is left unchanged.
> '
> ' Code Courtesy of
> ' Terry Kreft
> '
>
> Public Const GHND = &H42
> Public Const CF_TEXT = 1
> Private Const CF_ANSIONLY = &H400&
> Private Const CF_APPLY = &H200&
> Private Const CF_BITMAP = 2
> Private Const CF_DIB = 8
> Private Const CF_DIF = 5
> Private Const CF_DSPBITMAP = &H82
> Private Const CF_DSPENHMETAFILE = &H8E
> Private Const CF_DSPMETAFILEPICT = &H83
> Private Const CF_DSPTEXT = &H81
> Private Const CF_EFFECTS = &H100&
> Private Const CF_ENABLEHOOK = &H8&
> Private Const CF_ENABLETEMPLATE = &H10&
> Private Const CF_ENABLETEMPLATEHANDLE = &H20&
> Private Const CF_ENHMETAFILE = 14
> Private Const CF_FIXEDPITCHONLY = &H4000&
> Private Const CF_FORCEFONTEXIST = &H10000
> Private Const CF_GDIOBJFIRST = &H300
> Private Const CF_GDIOBJLAST = &H3FF
> Private Const CF_HDROP = 15
> Private Const CF_INITTOLOGFONTSTRUCT = &H40&
> Private Const CF_LIMITSIZE = &H2000&
> Private Const CF_LOCALE = 16
> Private Const CF_MAX = 17
> Private Const CF_METAFILEPICT = 3
> Private Const CF_NOFACESEL = &H80000
> Private Const CF_NOSCRIPTSEL = &H800000
> Private Const CF_NOSIMULATIONS = &H1000&
> Private Const CF_NOSIZESEL = &H200000
> Private Const CF_NOSTYLESEL = &H100000
> Private Const CF_NOVECTORFONTS = &H800&
> Private Const CF_NOOEMFONTS = CF_NOVECTORFONTS
> Private Const CF_NOVERTFONTS = &H1000000
> Private Const CF_OEMTEXT = 7
> Private Const CF_OWNERDISPLAY = &H80
> Private Const CF_PALETTE = 9
> Private Const CF_PENDATA = 10
> Private Const CF_PRINTERFONTS = &H2
> Private Const CF_PRIVATEFIRST = &H200
> Private Const CF_PRIVATELAST = &H2FF
> Private Const CF_RIFF = 11
> Private Const CF_SCALABLEONLY = &H20000
> Private Const CF_SCREENFONTS = &H1
> Private Const CF_BOTH = (CF_SCREENFONTS Or CF_PRINTERFONTS)
> Private Const CF_SCRIPTSONLY = CF_ANSIONLY
> Private Const CF_SELECTSCRIPT = &H400000
> Private Const CF_SHOWHELP = &H4&
> Private Const CF_SYLK = 4
> Private Const CF_TIFF = 6
> Private Const CF_TTONLY = &H40000
> Private Const CF_UNICODETEXT = 13
> Private Const CF_USESTYLE = &H80&
> Private Const CF_WAVE = 12
> Private Const CF_WYSIWYG = &H8000
>
> Private Declare Function GlobalAlloc Lib "kernel32" (ByVal wFlags&,
> ByVal _
>   dwBytes As Long) As Long
> Private Declare Function GlobalLock Lib "kernel32" (ByVal hMem As Long)
> _
>   As Long
> Private Declare Function GlobalSize Lib "kernel32" (ByVal hMem As Long)
> _
>   As Long
> Private Declare Function lstrcpy Lib "kernel32" (ByVal lpString1 As Any,
> _
>   ByVal lpString2 As Any) As Long
> Private Declare Function lstrlen Lib "kernel32" Alias "lstrlenA" _
>   (ByVal lpString As String) As Long
>
> Private Declare Function GlobalUnlock Lib "kernel32" (ByVal hMem As
> Long) _
>   As Long
>
> Private Declare Function OpenClipboard Lib "user32" (ByVal Hwnd As Long)
> _
>   As Long
> Private Declare Function CloseClipboard Lib "user32" () As Long
> Private Declare Function GetClipboardData Lib "user32" (ByVal wFormat As
> _
>   Long) As Long
> Private Declare Function EmptyClipboard Lib "user32" () As Long
> Private Declare Function SetClipboardData Lib "user32" (ByVal wFormat _
>   As Long, ByVal hMem As Long) As Long
>
> Function ClipBoard_SetText(strCopyString As String) As Boolean
>   Dim hGlobalMemory As Long
>   Dim lpGlobalMemory As Long
>   Dim hClipMemory As Long
>
>   ' Allocate moveable global memory.
>   '-------------------------------------------
>   hGlobalMemory = GlobalAlloc(GHND, Len(strCopyString) + 1)
>
>   ' Lock the block to get a far pointer
>   ' to this memory.
>   lpGlobalMemory = GlobalLock(hGlobalMemory)
>
>   ' Copy the string to this global memory.
>   lpGlobalMemory = lstrcpy(lpGlobalMemory, strCopyString)
>
>   ' Unlock the memory and then copy to the clipboard
>   If GlobalUnlock(hGlobalMemory) = 0 Then
>     If OpenClipboard(0&) <> 0 Then
>       Call EmptyClipboard
>       hClipMemory = SetClipboardData(CF_TEXT, hGlobalMemory)
>       ClipBoard_SetText = CBool(CloseClipboard)
>     End If
>   End If
> End Function
>
> Function ClipBoard_GetText() As String
>   Dim hClipMemory As Long
>   Dim lpClipMemory As Long
>   Dim strCBText As String
>   Dim retVal As Long
>   Dim lngSize As Long
>   If OpenClipboard(0&) <> 0 Then
>     ' Obtain the handle to the global memory
>     ' block that is referencing the text.
>     hClipMemory = GetClipboardData(CF_TEXT)
>     If hClipMemory <> 0 Then
>       ' Lock Clipboard memory so we can reference
>       ' the actual data string.
>       lpClipMemory = GlobalLock(hClipMemory)
>       If lpClipMemory <> 0 Then
>         lngSize = GlobalSize(lpClipMemory)
>         strCBText = Space$(lngSize)
>         retVal = lstrcpy(strCBText, lpClipMemory)
>         retVal = GlobalUnlock(hClipMemory)
>         ' Peel off the null terminating character.
>         strCBText = Left(strCBText, InStr(1, strCBText, Chr$(0), 0) - 1)
>       Else
>         MsgBox "Could not lock memory to copy string from."
>       End If
>     End If
>     Call CloseClipboard
>   End If
>   ClipBoard_GetText = strCBText
> End Function
>
> '*********  Code End   ************
>
> Her får du så muligheden for både at indlæse og udlæse data til og fra
> Clipboard'et.
>
> PS ! Håber du har ligget godt...
>
> --
> Med venlig hilsen
>
> Per

Ja jeg har ligget godt, og det virker tak for hurtigt svar.

Hilsen

Peter

Søg
Reklame
Statistik
Spørgsmål : 177424
Tips : 31962
Nyheder : 719565
Indlæg : 6407903
Brugere : 218877

Månedens bedste
Årets bedste
Sidste års bedste