Python ImportError:没有名为zhelper的模块。

时间:2021-03-10 23:16:31

I am trying to run the program given below(that I copied from zeromq tutorial).I am getting the error

我正在尝试运行下面给出的程序(我从zeromq教程中复制的)。我得到了误差

Python ImportError: No module named zhelpers

Python ImportError:没有名为zhelper的模块。

I have tried installing

我有试着安装

sudo apt-get install zhelpers
sudo pip install zhelpers

is giving the following errors.

是给出以下错误。

E: Unable to locate package zhelpers
OR
No distributions at all found for zhelpers

Can someone point out what is the exact name of the module that I should install.

有人能指出我应该安装的模块的确切名称吗?

How can I fix this error.

我如何修正这个错误。

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# This shows how to capture data using a pub-sub proxy
#
import time
from random import randint
from string import uppercase
from threading import Thread
import zmq
from zmq.devices import monitored_queue
from zhelpers import zpipe

# The subscriber thread requests messages starting with
# A and B, then reads and counts incoming messages.
def subscriber_thread():
    ctx = zmq.Context.instance()
    # Subscribe to "A" and "B"
    subscriber = ctx.socket(zmq.SUB)
    subscriber.connect("tcp://localhost:6001")
    subscriber.setsockopt(zmq.SUBSCRIBE, b"A")
    subscriber.setsockopt(zmq.SUBSCRIBE, b"B")
    count = 0
    while True:
        try:
            msg = subscriber.recv_multipart()
        except zmq.ZMQError as e:
            if e.errno == zmq.ETERM:
                break # Interrupted
    else:
        raise
        count += 1
        print ("Subscriber received %d messages" % count)
# .split publisher thread

# The publisher sends random messages starting with A-J:
def publisher_thread():
    ctx = zmq.Context.instance()
    publisher = ctx.socket(zmq.PUB)
    publisher.bind("tcp://*:6000")

    while True:
        string = "%s-%05d" % (uppercase[randint(0,10)], randint(0,100000))
        try:
            publisher.send(string)
        except zmq.ZMQError as e:
            if e.errno == zmq.ETERM:
                break # Interrupted
    else:
        raise
        time.sleep(0.1) # Wait for 1/10th second
# .split listener thread
# The listener receives all messages flowing through the proxy, on its
# pipe. Here, the pipe is a pair of ZMQ_PAIR sockets that connects
# attached child threads via inproc. In other languages your mileage may vary:

def listener_thread (pipe):
    # Print everything that arrives on pipe
    while True:
        try:
            print (pipe.recv_multipart())
        except zmq.ZMQError as e:
            if e.errno == zmq.ETERM:
                break # Interrupted

# .split main thread
# The main task starts the subscriber and publisher, and then sets
# itself up as a listening proxy. The listener runs as a child thread:
def main ():
    # Start child threads
    ctx = zmq.Context.instance()
    p_thread = Thread(target=publisher_thread)
    s_thread = Thread(target=subscriber_thread)
    p_thread.start()
    s_thread.start()
    pipe = zpipe(ctx)

    subscriber = ctx.socket(zmq.XSUB)
    subscriber.connect("tcp://localhost:6000")
    publisher = ctx.socket(zmq.XPUB)
    publisher.bind("tcp://*:6001")
    l_thread = Thread(target=listener_thread, args=(pipe[1],))
    l_thread.start()
    try:
        monitored_queue(subscriber, publisher, pipe[0], 'pub', 'sub')
    except KeyboardInterrupt:
        print ("Interrupted")

    del subscriber, publisher, pipe
    ctx.term()
    if __name__ == '__main__':
        main()

1 个解决方案

#1


4  

You can download all the examples of the zeromq guide here. There you have also zhelpers.py.

你可以在这里下载zeromq指南的所有例子。还有zhelpers.py。

#1


4  

You can download all the examples of the zeromq guide here. There you have also zhelpers.py.

你可以在这里下载zeromq指南的所有例子。还有zhelpers.py。