如何用C#实现对Excel中Paste事件的捕获

背景: 在开发excel插件(shared addin)的时候, 需要知道用户什么时候要做“粘贴”这个动作, 并对剪切板的内容进行一些操作, 虽然有clip board相关接口从而知道剪切板是不是变化了,但是excel本身并没有onPaste这种事件,所以无法准确地在粘贴之前做出操作。

问题: 有什么办法能完美的判断并捕获"onPaste"事件吗?

目前的进展 : google一番之后,最简洁的方法是onSheetChange时从undo list中找到最后一个action,然后判断它是不是粘贴, 这种方法的问题是, 得到的action是一个已经本地化的字符串, 比如中文版本的excel得到的是“粘贴”, 而英文就是"Paste"。

阅读 5.2k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进