【问题标题】:how to monitor the subprocess realtime如何实时监控子进程
【发布时间】:2012-05-26 23:57:29
【问题描述】:

我是python的新手。

我目前正在做一个项目。

通过单击按钮A,命令“adb shell getevent”将在一个子进程中执行。 结果将写入文件。 如果有人点击连接的设备,就会不时出现结果。

点击按钮 B 将停止。

class MyClass():
...
    def recordCmd(self):
        cmd = []
        cmd.append("adb")
        cmd.append("shell")
        cmd.append("getevent")
        cmd.append("/dev/input/event0")
        p = subprocess.Popen(cmd, stdin=PIPE, stdout=PIPE)
        for line in p.stdout:
            print line

    def OnRecordEvent(self, event):
    '''
     call "adb shell getevent /dev/input/event0 " to collect events
     '''
    mp = multiprocessing.Process(target=self.recordCmd, args=(self,))
    mp.daemon= True
    mp.start()
....

这不起作用,抛出以下错误:

File "C:\Python27\lib\multiprocessing\forking.py", line 271, in __init__
dump(process_obj, to_child, HIGHEST_PROTOCOL)
File "C:\Python27\lib\multiprocessing\forking.py", line 193, in dump
ForkingPickler(file, protocol).dump(obj)
File "C:\Python27\lib\pickle.py", line 224, in dump
self.save(obj)
File "C:\Python27\lib\pickle.py", line 331, in save
self.save_reduce(obj=obj, *rv)
File "C:\Python27\lib\pickle.py", line 419, in save_reduce
save(state)
File "C:\Python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "C:\Python27\lib\pickle.py", line 649, in save_dict
self._batch_setitems(obj.iteritems())
File "C:\Python27\lib\pickle.py", line 681, in _batch_setitems
save(v)
File "C:\Python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "C:\Python27\lib\multiprocessing\forking.py", line 66, in dispatcher
self.save_reduce(obj=obj, *rv)
File "C:\Python27\lib\pickle.py", line 401, in save_reduce
save(args)
File "C:\Python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "C:\Python27\lib\pickle.py", line 548, in save_tuple
save(element)
File "C:\Python27\lib\pickle.py", line 331, in save
self.save_reduce(obj=obj, *rv)
File "C:\Python27\lib\pickle.py", line 419, in save_reduce
save(state)
File "C:\Python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "C:\Python27\lib\pickle.py", line 649, in save_dict
self._batch_setitems(obj.iteritems())
File "C:\Python27\lib\pickle.py", line 681, in _batch_setitems
save(v)
File "C:\Python27\lib\pickle.py", line 331, in save
self.save_reduce(obj=obj, *rv)
File "C:\Python27\lib\pickle.py", line 419, in save_reduce
save(state)
File "C:\Python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "C:\Python27\lib\pickle.py", line 649, in save_dict
self._batch_setitems(obj.iteritems())
File "C:\Python27\lib\pickle.py", line 686, in _batch_setitems
save(v)
File "C:\Python27\lib\pickle.py", line 331, in save
self.save_reduce(obj=obj, *rv)
File "C:\Python27\lib\pickle.py", line 396, in save_reduce
save(cls)
File "C:\Python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "C:\Python27\lib\pickle.py", line 748, in save_global
(obj, module, name))
pickle.PicklingError: Can't pickle <type 'PySwigObject'>: it's not found as __builtin__.PySwigObject

谁能帮我解决这个问题?

【问题讨论】:

    标签: python subprocess multiprocessing monitor interactive


    【解决方案1】:

    multiprocessing 在进程之间复制对象时使用pickle。该错误消息似乎表明MyClass 包含无法腌制的内容。

    您可以将recordCmd 函数从类中取出,因为它无论如何都没有引用self

    【讨论】:

      猜你喜欢
      • 2013-07-29
      • 1970-01-01
      • 1970-01-01
      • 2023-03-24
      • 1970-01-01
      • 1970-01-01
      • 2018-08-01
      • 1970-01-01
      • 2018-10-20
      相关资源
      最近更新 更多