我只需要一个python脚本,复制文本到剪贴板。
脚本执行后,我需要文本的输出被粘贴到另一个源。 是否有可能编写一个python脚本来完成这项工作?
我只需要一个python脚本,复制文本到剪贴板。
脚本执行后,我需要文本的输出被粘贴到另一个源。 是否有可能编写一个python脚本来完成这项工作?
当前回答
看到Pyperclip。示例(摘自Pyperclip网站):
import pyperclip
pyperclip.copy('The text to be copied to the clipboard.')
spam = pyperclip.paste()
另外,请参阅施乐公司。但它似乎有更多的依赖性。
其他回答
还有一个需要改进的答案: https://stackoverflow.com/a/4203897/2804197 https://stackoverflow.com/a/25476462/1338797 (Tkinter)。
Tkinter很好,因为它要么包含在Python (Windows)中,要么易于安装(Linux),因此对最终用户的依赖性很小。
这里我有一个“成熟”的例子,它将参数或标准输入复制到剪贴板,并且-当不在Windows上时-等待用户关闭应用程序:
import sys
try:
from Tkinter import Tk
except ImportError:
# welcome to Python3
from tkinter import Tk
raw_input = input
r = Tk()
r.withdraw()
r.clipboard_clear()
if len(sys.argv) < 2:
data = sys.stdin.read()
else:
data = ' '.join(sys.argv[1:])
r.clipboard_append(data)
if sys.platform != 'win32':
if len(sys.argv) > 1:
raw_input('Data was copied into clipboard. Paste and press ENTER to exit...')
else:
# stdin already read; use GUI to exit
print('Data was copied into clipboard. Paste, then close popup to exit...')
r.deiconify()
r.mainloop()
else:
r.destroy()
这展示了:
在Py2和Py3上导入Tk Raw_input和print()的兼容性 “unhiding”Tk根窗口时,需要 在Linux上以两种不同的方式等待退出。
这是@Martin Thoma对GTK3的回答的修改版本。我发现原来的解决方案导致过程永远不会结束,当我调用脚本时,我的终端挂起。将脚本更改为以下内容为我解决了这个问题。
#!/usr/bin/python3
from gi.repository import Gtk, Gdk
import sys
from time import sleep
class Hello(Gtk.Window):
def __init__(self):
super(Hello, self).__init__()
clipboardText = sys.argv[1]
clipboard = Gtk.Clipboard.get(Gdk.SELECTION_CLIPBOARD)
clipboard.set_text(clipboardText, -1)
clipboard.store()
def main():
Hello()
if __name__ == "__main__":
main()
你可能想要改变clipboardText被赋值的对象,在这个脚本中,它被赋值给调用脚本的参数。
在一个新的ubuntu 16.04安装中,我发现我必须安装python-gobject包才能使它正常工作而不会出现模块导入错误。
在macOS上,使用subprocess.run将你的文本管道到pbcopy:
import subprocess
data = "hello world"
subprocess.run("pbcopy", text=True, input=data)
它将“hello world”复制到剪贴板。
看到Pyperclip。示例(摘自Pyperclip网站):
import pyperclip
pyperclip.copy('The text to be copied to the clipboard.')
spam = pyperclip.paste()
另外,请参阅施乐公司。但它似乎有更多的依赖性。
PyQt5:
from PyQt5.QtWidgets import QApplication
import sys
def main():
app = QApplication(sys.argv)
cb = QApplication.clipboard()
cb.clear(mode=cb.Clipboard )
cb.setText("Copy to ClipBoard", mode=cb.Clipboard)
# Text is now already in the clipboard, no need for further actions.
sys.exit()
if __name__ == "__main__":
main()