當前位置: 首頁>>代碼示例>>Python>>正文


Python msgpack.unpackb方法代碼示例

本文整理匯總了Python中msgpack.unpackb方法的典型用法代碼示例。如果您正苦於以下問題:Python msgpack.unpackb方法的具體用法?Python msgpack.unpackb怎麽用?Python msgpack.unpackb使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在msgpack的用法示例。


在下文中一共展示了msgpack.unpackb方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __unchunk

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def __unchunk(self, new_message, worker_name):
		new = msgpack.unpackb(new_message, encoding='utf-8', use_list=False)

		# If we don't have a chunking type, it's probably an old-style message.
		if not 'chunk-type' in new:
			return new

		# Messages smaller then the chunk_size are not split, and can just be returned.
		if new['chunk-type'] == "complete-message":
			assert 'chunk-type' in new
			assert 'data'       in new
			return new['data']
		elif new['chunk-type'] == "chunked-message":
			return self.__process_chunk(new, worker_name)
		else:
			raise RuntimeError("Unknown message type: %s", new['chunk-type']) 
開發者ID:fake-name,項目名稱:ReadableWebProxy,代碼行數:18,代碼來源:MessageProcessor.py

示例2: get_available_jobs

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def get_available_jobs(self):
		ret = []
		for job_netloc, key_dict in self.url_throttler.items():
			try:
				# Allow unlimited fetching if the site isn't erroring at all
				while key_dict['active_fetches'] <= key_dict['status_accumulator']:
					# ret.append(item['job_queue'].get(block=False))
					item_b = self.redis.lpop(self.__netloc_to_key(job_netloc))
					if not item_b:  # Nothing in queue
						break
					item = msgpack.unpackb(item_b, use_list=False, raw=False)
					ret.append(item)
					key_dict['active_fetches'] += 1
					self.total_queued -= 1
			except queue.Empty:
				pass

		self.log.info("Extracted %s jobs from rate-limiting queues.", len(ret))

		return ret 
開發者ID:fake-name,項目名稱:ReadableWebProxy,代碼行數:22,代碼來源:NetlocThrottler.py

示例3: _request

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def _request(self, message):
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        sock.connect(self.server_address)
        sock.send(msgpack.packb(message, use_bin_type=True))

        buff = bytes()
        while True:
            block = sock.recv(128)
            if not block:
                break
            buff += block
        resp = msgpack.unpackb(buff, encoding='utf-8')
        sock.close()
        if 'type' in resp and resp['type'] == 'redirect':
            self.server_address = tuple(resp['leader'])
            resp = self._request(message)
        return resp 
開發者ID:simonacca,項目名稱:zatt,代碼行數:19,代碼來源:abstractClient.py

示例4: wait

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def wait(self):
        results = []
        print
        "selecting"
        r, w, e = select.select(self.clients, (), ())
        for sock_ready in r:
            if sock_ready == self.listener:
                print
                "accepting new client"
                c = self.listener.accept()
                self.clients.append(c)
            else:
                try:
                    msg = sock_ready.recv_bytes()
                    msg = msgpack.unpackb(msg)
                    results.append((sock_ready, msg))
                    # print "received {}".format(msg)
                except EOFError:
                    print
                    "closing"
                    sock_ready.close()
                    self.clients.remove(sock_ready)
        return results 
開發者ID:RUB-SysSec,項目名稱:grimoire,代碼行數:25,代碼來源:communicator.py

示例5: test_pex_manylinux_runtime

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def test_pex_manylinux_runtime():
  """Tests resolver manylinux support and runtime resolution (and --platform=current)."""
  test_stub = dedent(
    """
    import msgpack
    print(msgpack.unpackb(msgpack.packb([1, 2, 3])))
    """
  )

  with temporary_content({'tester.py': test_stub}) as output_dir:
    pex_path = os.path.join(output_dir, 'test.pex')
    tester_path = os.path.join(output_dir, 'tester.py')
    results = run_pex_command(['--disable-cache',
                               '--no-build',
                               'msgpack-python==0.4.7',
                               '--platform=current',
                               '-o', pex_path])
    results.assert_success()

    out = subprocess.check_output([pex_path, tester_path])
    assert out.strip() == '[1, 2, 3]' 
開發者ID:pantsbuild,項目名稱:pex,代碼行數:23,代碼來源:test_integration.py

示例6: test_enqueue_payload_encode_decode

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def test_enqueue_payload_encode_decode(self):
        job_id = self._get_job_id()
        response = self.queue.enqueue(
            payload=self._test_payload_1,
            interval=10000,  # 10s (10000ms)
            job_id=job_id,
            queue_id=self._test_queue_id,
            queue_type=self._test_queue_type,
        )

        payload_map_name = '%s:payload' % (self.queue._key_prefix)
        payload_map_key = '%s:%s:%s' % (
            self._test_queue_type, self._test_queue_id, job_id)
        raw_payload = self.queue._r.hget(payload_map_name, payload_map_key)
        # decode the payload from msgpack to dictionary
        payload = msgpack.unpackb(raw_payload[1:-1])
        self.assertEqual(payload, self._test_payload_1) 
開發者ID:plivo,項目名稱:sharq,代碼行數:19,代碼來源:test_func.py

示例7: downgrade

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def downgrade():
    conn = op.get_bind()

    temp_log_table = op.create_table(
        'temp_log',
        sa.Column('id', sa.Integer(), nullable=False),
        sa.Column('result_id', sa.Integer(), nullable=True),
        sa.Column('data', sa.String(length=1024), nullable=True),
        sa.ForeignKeyConstraint(['result_id'], ['result.id'], ),
        sa.PrimaryKeyConstraint('id'))
    res = conn.execute('SELECT id, result_id, data FROM log')
    results = res.fetchall()
    if len(results) > 0:
        modified_logs = [{
            'id': r[0],
            'result_id': r[1],
            'data': json.dumps(msgpack.unpackb(r[2], raw=False))}
            for r in results]
        op.bulk_insert(temp_log_table, modified_logs)
    op.drop_table('log')
    op.rename_table('temp_log', 'log') 
開發者ID:chainer,項目名稱:chainerui,代碼行數:23,代碼來源:e3db52a480f8_alter_log_data_type.py

示例8: serialize

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def serialize(self):
        """serialize."""

        log_dict = {}

        data = msgpack.unpackb(self.data, raw=False)
        for item in data.items():
            value_to_store = (
                None
                if not isinstance(item[1], numbers.Number)
                or isinf(item[1])
                or isnan(item[1])
                else item[1]
            )

            log_dict[item[0]] = value_to_store

        return {
            'id': self.id,
            'resultId': self.result_id,
            'logDict': log_dict
        } 
開發者ID:chainer,項目名稱:chainerui,代碼行數:24,代碼來源:log.py

示例9: fetch_by_name

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def fetch_by_name(self, name):
        import requests
        logger.debug("Requesting info about entry named '%s'", name)
        params = {'name': name}
        http_args = self._get_http_args(params)
        response = requests.get(self.source_url, **http_args)
        if response.status_code == 404:
            raise KeyError(name)
        try:
            response.raise_for_status()
        except requests.HTTPError as err:
            raise RemoteCatalogError(
                "Failed to fetch entry {!r}.".format(name)) from err
        info = msgpack.unpackb(response.content, **unpack_kwargs)
        return RemoteCatalogEntry(
            url=self.url,
            getenv=self.getenv,
            getshell=self.getshell,
            auth=self.auth,
            http_args=self.http_args,
            page_size=self._page_size,
            **info['source']) 
開發者ID:intake,項目名稱:intake,代碼行數:24,代碼來源:base.py

示例10: search

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def search(self, *args, **kwargs):
        import requests
        request = {'action': 'search', 'query': (args, kwargs),
                   'source_id': self._source_id}
        response = requests.post(
            url=self.source_url, **self._get_http_args({}),
            data=msgpack.packb(request, **pack_kwargs))
        try:
            response.raise_for_status()
        except requests.HTTPError as err:
            raise RemoteCatalogError("Failed search query.") from err
        source = msgpack.unpackb(response.content, **unpack_kwargs)
        source_id = source['source_id']
        cat = RemoteCatalog(
            url=self.url,
            http_args=self.http_args,
            source_id=source_id,
            name="")
        cat.cat = self
        return cat 
開發者ID:intake,項目名稱:intake,代碼行數:22,代碼來源:base.py

示例11: resolve_types

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def resolve_types(self, ret):
        if not self.pipeline_mode:
            try:
                key_with_types = msgpack.unpackb(self.resolve_types_script(ret))
            except ResponseError as e:
                if "CROSSSLOT" not in repr(e):
                    raise e
                key_with_types = self.resolve_with_pipe(ret)
                self.pipeline_mode = True
        else:
            key_with_types = self.resolve_with_pipe(ret)

        for i in range(0, len(ret)):
            yield key_with_types[i], ret[i]

        ret.clear() 
開發者ID:gamenet,項目名稱:redis-memory-analyzer,代碼行數:18,代碼來源:scanner.py

示例12: raw_decode

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def raw_decode(cls, data, content_encoding=None):
        content_encoding = ContentEncoding.of(content_encoding)
        if content_encoding.is_gzip:
            try:
                data = gzip.decompress(data)
            except (ValueError, TypeError):
                raise ActorMessageDecodeError('gzip decompress failed')
        try:
            if content_encoding.is_json:
                data = json.loads(data.decode('utf-8'))
            else:
                data = msgpack.unpackb(data, raw=False)
        except json.JSONDecodeError:
            raise ActorMessageDecodeError('json decode failed')
        except msgpack.UnpackException:
            raise ActorMessageDecodeError('msgpack decode failed')
        return data 
開發者ID:anyant,項目名稱:rssant,代碼行數:19,代碼來源:message.py

示例13: proxy_receive

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def proxy_receive(cls, connection):
        str_success = connection.recv(1)
        if len(str_success) != 1:
            raise TensorforceError.unexpected()
        success = bool(str_success)

        str_num_bytes = connection.recv(8)
        if len(str_num_bytes) != 8:
            raise TensorforceError.unexpected()
        num_bytes = int(str_num_bytes.decode())
        str_result = b''
        for n in range(num_bytes // cls.MAX_BYTES):
            str_result += connection.recv(cls.MAX_BYTES)
            if len(str_result) != n * cls.MAX_BYTES:
                raise TensorforceError.unexpected()
        str_result += connection.recv(num_bytes % cls.MAX_BYTES)
        if len(str_result) != num_bytes:
            raise TensorforceError.unexpected()
        result = msgpack.unpackb(packed=str_result)
        decode = (lambda x: x.decode() if isinstance(x, bytes) else x)
        result = util.fmap(function=decode, xs=result, map_keys=True)

        return success, result 
開發者ID:tensorforce,項目名稱:tensorforce,代碼行數:25,代碼來源:socket_environment.py

示例14: loads

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def loads(s, **kwargs):
    """ An overload of msgpack.loads that works with pyGSTi types """
    decoded_msgpack = _msgpack.unpackb(s, **kwargs)  # load normal MSGPACK
    return decode_obj(decoded_msgpack, msgpack_uses_binary_strs)  # makes pygsti objects 
開發者ID:pyGSTio,項目名稱:pyGSTi,代碼行數:6,代碼來源:msgpack.py

示例15: loadsCall

# 需要導入模塊: import msgpack [as 別名]
# 或者: from msgpack import unpackb [as 別名]
def loadsCall(self, data):
        return msgpack.unpackb(self._convertToBytes(data), raw=False, object_hook=self.object_hook) 
開發者ID:irmen,項目名稱:Pyro5,代碼行數:4,代碼來源:serializers.py


注:本文中的msgpack.unpackb方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。