我的编程空间,编程开发者的网络收藏夹
学习永远不晚

来自回调 tkinter 的多处理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

来自回调 tkinter 的多处理

问题内容

问题是当我想从回调 tkinter(特别是函数 tkinter 的绑定)触发进程“多重处理”时。错误从这里开始:

file“c:\users\usuario\downloads\engine_controller_ls\extracttext\funciones\reproductor.py”,第 598 行,在 __init__ p.start() 文件“c:\program files\python311\lib\multiprocessing\process .py”,第 121 行,开始 self._popen = self._popen(self) ^^^^^^^^^^^^^^^^^^ 文件“c:\program files\python311\lib\multiprocessing\ context.py”,第 224 行,在 _popen 中返回 _default_context.get_context().process._popen(process_obj) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 文件“c:\program files\python311\lib\multiprocessing\context.py”,第 336 行,在 _popen 返回 popen(process_obj) ^^^^^^^^^^^^^^^^^^^ 文件 "c:\program files\python311\lib\multiprocessing\popen_spawn_win32.py",第 95 行,在 __init__duction.dump(process_obj, to_child) 文件“c:\program files\python311\lib\multiprocessing\reduction.py”中,第 60 行,在转储 forkingpickler(file, protocol).dump(obj) 中 typeerror: 无法 pickle ' _tkinter.tkapp'对象

ma​​in.py

from reproductor import mediaplayer

def item_selected(event):
    """
    evento invocado cuando el contenido de una carpeta es abierto.
    """
    item_seleccionado = arbol.selection()
    item = arbol.item(item_seleccionado)
    print(item)
    
    #extraer la ruta del archivo y si encuentra espacios unirlos
    ruta = ""
    for element in item["values"]:
        ruta += element + " "

    
    #iniciacion del video
    global reproductor_video

    # cerrar el video para que no se abra en multiples ventanas
    if reproductor_video is not none:
        reproductor_video.closeplayer()
    
    reproductor_video = mediaplayer(ruta, frame_visualizer, frame_botones_procesar, spininicio=inbox_inicio, spinfinal=inbox_fin, spinactual=inbox_actual, mainvideo=true)
    reproductor_video.update_progres_video()

arbol = checkboxtreeview(frame_tree_in)
arbol.bind("<<treeviewselect>>", item_selected)

reproductor.py

class MediaPlayer:
    def __init__(ruta, frame_visualizer, frame_botones_procesar, spinInicio=inBox_inicio, spinFinal=inBox_fin, spinActual=inBox_Actual, mainVideo=True):
        p = Process(target=self.funcion1)
        p.start()
        #p.join

    def funcion1(self):
        cont = 0
        while cont < 100:
            cont += 1
            print("contador =", cont)

我在主函数中尝试了相同的代码,并且它执行得很好,但是从回调中它不会执行。


正确答案


原版

解决方案在这里为那些需要它的人提供,实际上,如果它可以从 tkinter 上的事件启动,如下所示:

翻译(谷歌翻译):

解决方案在这里为那些需要它的人提供,事实上它可以从 tkinter 中的事件启动,如下所示:

from multiprocessing import Process, log_to_stderr, get_logger
import time
from tkinter import Tk
from tkinter import ttk
import logging
import sys


def item_selected(event):
    
    my_objeto = objeto()
    button_eraser.config(command=lambda:my_objeto.lanzador(2))
    button_marco.config(command=lambda:my_objeto.lanzador(1))
    my_objeto.start_player()

class objeto:

    def __init__(self) -> None:
        #self.start_player()
        pass
    
    def start_player(self):
        pass
        

    def funcion1(self):
        contador = 0
        while 1:
            contador += 1
            print("Func1: ", contador, self.palabra)
            time.sleep(0.1)
            
            if contador > 80:
                break
        
        q = Process(target=self.funcion3)
        q.start()
        #q.join()
    
    def funcion2(self):
        contador = 0
        while 1:
            contador += 2
            print("Func2: ", contador)
            time.sleep(0.2)
            if contador > 120:
                break
    
    def funcion3(self):
        contador = 0
        while 1:
            contador += 2
            print("Func3: ", contador)
            time.sleep(0.02)
            if contador > 200:
                break
    
    def lanzador(self,mode):
        log_to_stderr(logging.DEBUG)
        logger = get_logger()
        logger.setLevel(logging.INFO)

        if mode == 1:
            self.p = Process(target=self.funcion1)
            self.p.start()
        elif mode == 2:
            self.p = Process(target=self.funcion2)
            self.p.start()
        
    def unir(self):
        self.p.join()
        print("Salio")

    def iniciar_multis(self):
        self.lanzador(2)
        self.lanzador(1)

以上就是来自回调 tkinter 的多处理的详细内容,更多请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

来自回调 tkinter 的多处理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

来自回调 tkinter 的多处理

问题内容问题是当我想从回调 tkinter(特别是函数 tkinter 的绑定)触发进程“多重处理”时。错误从这里开始:file“c:\users\usuario\downloads\engine_controller_ls\extra
来自回调 tkinter 的多处理
2024-02-22

命名来自多重返回函数的接收变量

对于一个Golang开发者来说,牢固扎实的基础是十分重要的,编程网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《命名来自多重返回函数的接收变量》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!问
命名来自多重返回函数的接收变量
2024-04-05

Nodejs异步回调的优雅处理方法

前言 Nodejs最大的亮点就在于事件驱动, 非阻塞I/O 模型,这使得Nodejs具有很强的并发处理能力,非常适合编写网络应用。在Nodejs中大部分的I/O操作几乎都是异步的,也就是我们处理I/O的操作结果基本上都需要在回调函数中处理,
2022-06-04

golang函数多个返回值的处理

go 语言函数支持返回多个值,通过逗号分隔类型声明。使用 x, y := myfunction() 获取返回值。例如,calculaterectangle 函数返回面积和周长,可通过 area, perimeter := calculate
golang函数多个返回值的处理
2024-04-22

深入浅析NodeJs并发异步的回调处理

这里说并发异步,并不准确,应该说连续异步。NodeJs单线程异步的特性,直接导致多个异步同时进行时,无法确定最后的执行结果来回调。举个简单的例子:for(var i = 0; i < 5; i++) {fs.readFile('file',
2022-06-04

Python的Twisted框架中使用Deferred对象来管理回调函数

首先抛出我们在讨论使用回调编程时的一些观点:激活errback是非常重要的。由于errback的功能与except块相同,因此用户需要确保它们的存在。他们并不是可选项,而是必选项。不在错误的时间点激活回调与在正确的时间点激活回调同等重要。典
2022-06-04

C++ 函数调用详解:返回值处理的艺术

c++++ 函数调用中的返回值处理涉及:返回值类型:定义返回数据的类型,包括原始类型和引用类型。返回值语义:决定函数如何处理返回值,包括值传递(副本返回)和引用传递(返回引用)。实战案例:说明值传递和引用传递的使用场景和实现方式。C++ 函
C++ 函数调用详解:返回值处理的艺术
2024-05-03

C++ 函数调用重载机制:参数传递和返回值的多义性处理

c++++ 函数重载允许同一函数名定义多个变体,根据不同形参列表区分。参数传递有值传递和引用传递两种,值传递将值复制到局部变量,引用传递将引用传递给函数,修改引用会影响外部变量。函数可返回不同类型的值,包括基本数据类型、引用和对象。C++
C++ 函数调用重载机制:参数传递和返回值的多义性处理
2024-05-01

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录