在VB或VBA中,如何调用API复制文本到剪贴板

本文介绍了一种在VBA中更稳定地将文本复制到剪贴板的方法,通过调用API来替代传统的DataObject方法,提高了操作的稳定性。
部署运行你感兴趣的模型镜像

在VBA中经常使用以下语句,来复制文本到剪贴板,但有时会出错。
  Dim MyData As New DataObject
     MyData.SetText sData, 1
     MyData.PutInClipboard

为了复制文本到剪贴板更加稳定,应该调用API来处理:

'复制文本到剪贴板
Public Sub CopyTextToClip(sData As String)
   If CBool(OpenClipboard(0)) Then
  
      Dim hMemHandle As Long, lpData As Long
     
      hMemHandle = GlobalAlloc(0, LenB(sData) + 2)
     
      If CBool(hMemHandle) Then
              
         lpData = GlobalLock(hMemHandle)
         If lpData <> 0 Then
           
            CopyMemory ByVal lpData, ByVal sData, LenB(sData)
            GlobalUnlock hMemHandle
            EmptyClipboard
            SetClipboardData CF_TEXT, hMemHandle
                       
         End If
     
      End If
  
      Call CloseClipboard
   End If

End Sub

 

您可能感兴趣的与本文相关的镜像

Linly-Talker

Linly-Talker

AI应用

Linly-Talker是一款创新的数字人对话系统,它融合了最新的人工智能技术,包括大型语言模型(LLM)、自动语音识别(ASR)、文本到语音转换(TTS)和语音克隆技术

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值