Использование PyperClip в веб-приложении

Я использую pyperclip.py, чтобы получить список адресов электронной почты в моем веб-приложении, используя форму, чтобы пользователь мог вставить его локально через буфер обмена. Он отлично работает локально. Однако при запуске на сервере (Linux 14.04 с Apache2) и доступе из клиентской системы через браузер копирование не происходит. Как я могу заставить его копировать в буфер обмена клиентской системы?

Сейчас я просто пытаюсь заставить его работать, и поэтому я использую только одну строку. Я использую pyperclip 1.5.15 с xclip и Python 3.4. Сервер работает под управлением Linux 14.04, и клиент заметил проблемы в Windows 8 и Windows 10 при использовании Google Chrome и IE. Ни одна другая ОС в настоящее время не тестировалась.

pyperclip.copy("HELLO") 

person Obj3ctiv3_C_88    schedule 21.10.2015    source источник


Ответы (1)


Поскольку я не смог найти много подробностей по этому вопросу, я решил ответить на свой вопрос. К сожалению, похоже, что браузеры не будут поддерживать pyperclip, поэтому требуется обходной путь HTML + Javascript (имеется в виду pyperclip). Во-первых, добавьте свой шаблон Django в качестве атрибута HTML, оттуда вы можете использовать Javascript для обработки функций копирования. Ниже приведен пример того, как это сделать, заранее извините, потому что stackoverflow придавал этому примеру какое-то странное форматирование. Также предполагается, что у вас есть форма ниже с идентификатором email_list_clipboard. Я надеюсь, что это поможет всем, кто может столкнуться с подобной проблемой!

Пример:

    <html email-list="{{request.session.email_list}}">
    <script>
        $(document).ready(function () {
            function copyTextToClipboard(text) {
                var textArea = document.createElement("textarea");

                // Place in top-left corner of screen regardless of scroll position.
                textArea.style.position = 'fixed';
                textArea.style.top = 0;
                textArea.style.left = 0;

                textArea.style.width = '2em';
                textArea.style.height = '2em';

                // We don't need padding, reducing the size if it does flash render.
                textArea.style.padding = 0;

                textArea.style.border = 'none';
                textArea.style.outline = 'none';
                textArea.style.boxShadow = 'none';

                textArea.style.background = 'transparent';

                textArea.value = text;

                document.body.appendChild(textArea);

                textArea.select();

                try {
                    var successful = document.execCommand('copy');
                    var msg = successful ? 'successful' : 'unsuccessful';
            console.log('Copying text command was ' + msg);
                } catch (err) {
                    console.log('Oops, unable to copy');
                }

                document.body.removeChild(textArea);
            }

            // set things up so my function will be called when field_three changes
            $('#email_list_clipboard').click(function (click) {
                event.preventDefault();
                copyTextToClipboard(document.documentElement.getAttribute("email-list"));
    });

</script>
person Obj3ctiv3_C_88    schedule 21.10.2015