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


Python rapidjson.loads方法代碼示例

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


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

示例1: users

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def users(self, request: web.Request):
        cached = await RedisDB.instance().get("apiuserscache")
        if cached is not None:
            return web.json_response(
                data=json.loads(cached),
                dumps=json.dumps
            )
        # Get all of not cached
        users = await User.all().prefetch_related('account')
        resp = []
        for user in users:
            resp.append(
                {
                    'user_id': user.id,
                    'user_last_known_name': user.name,
                    'address': user.account.address,
                    'created_ts_utc': self.format_js_iso(user.created_at)
                }
            )
        await RedisDB.instance().set("apiuserscache", json.dumps(resp), expires=1800)
        return web.json_response(
            data=resp,
            dumps=json.dumps
        ) 
開發者ID:bbedward,項目名稱:graham_discord_bot,代碼行數:26,代碼來源:server.py

示例2: validate_id

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def validate_id(tx_body):
        """Validate the transaction ID of a transaction

            Args:
                tx_body (dict): The Transaction to be transformed.
        """
        # NOTE: Remove reference to avoid side effects
        # tx_body = deepcopy(tx_body)
        tx_body = rapidjson.loads(rapidjson.dumps(tx_body))

        try:
            proposed_tx_id = tx_body['id']
        except KeyError:
            raise InvalidHash('No transaction id found!')

        tx_body['id'] = None

        tx_body_serialized = Transaction._to_str(tx_body)
        valid_tx_id = Transaction._to_hash(tx_body_serialized)

        if proposed_tx_id != valid_tx_id:
            err_msg = ("The transaction's id '{}' isn't equal to "
                       "the hash of its body, i.e. it's not valid.")
            raise InvalidHash(err_msg.format(proposed_tx_id)) 
開發者ID:bigchaindb,項目名稱:bigchaindb,代碼行數:26,代碼來源:transaction.py

示例3: store_bulk_transactions

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def store_bulk_transactions(self, transactions):
        txns = []
        assets = []
        txn_metadatas = []
        for t in transactions:
            transaction = t.tx_dict if t.tx_dict else rapidjson.loads(rapidjson.dumps(t.to_dict()))
            if transaction['operation'] == t.CREATE:
                asset = transaction.pop('asset')
                asset['id'] = transaction['id']
                assets.append(asset)

            metadata = transaction.pop('metadata')
            txn_metadatas.append({'id': transaction['id'],
                                  'metadata': metadata})
            txns.append(transaction)

        backend.query.store_metadatas(self.connection, txn_metadatas)
        if assets:
            backend.query.store_assets(self.connection, assets)
        return backend.query.store_transactions(self.connection, txns) 
開發者ID:bigchaindb,項目名稱:bigchaindb,代碼行數:22,代碼來源:lib.py

示例4: _init_json

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def _init_json(self):
        # rapidjson is well maintained library with acceptable performance, good choice
        if self.options['json_lib'] == 'rapidjson':
            import rapidjson

            self.json_encode = lambda x: rapidjson.dumps(x, number_mode=rapidjson.NM_NATIVE)
            self.json_decode = lambda x: rapidjson.loads(x, number_mode=rapidjson.NM_NATIVE)

        # ujson provides best performance in our tests, but it is abandoned by maintainers
        elif self.options['json_lib'] == 'ujson':
            import ujson

            self.json_encode = ujson.dumps
            self.json_decode = ujson.loads

        # json from Python stdlib, very safe choice, but slow
        elif self.options['json_lib'] == 'json':
            import json

            self.json_encode = json.dumps
            self.json_decode = json.loads

        else:
            raise ValueError(f"Unsupported json library [{self.options['json_lib']}]") 
開發者ID:badoo,項目名稱:pyexasol,代碼行數:26,代碼來源:connection.py

示例5: loads

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def loads(string: str, *args, **kwargs) -> Dict:
    kwargs = add_settings_to_kwargs(kwargs)
    return rapidjson.loads(string, *args, **kwargs) 
開發者ID:alexferl,項目名稱:falcon-boilerplate,代碼行數:5,代碼來源:json.py

示例6: callback

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def callback(self, request: web.Request):
        """Route for handling HTTP callback"""
        request_json = await request.json()
        hash = request_json['hash']
        self.logger.debug(f"callback received {hash}")
        # cache
        if not await RedisDB.instance().exists(f"callback:{hash}"):
            await RedisDB.instance().set(f"callback:{hash}", "val", expires=300)
        else:
            return web.HTTPOk()
        # De-serialize block
        request_json['block'] = json.loads(request_json['block'])
        # only consider sends
        if 'is_send' in request_json and (request_json['is_send'] or request_json['is_send'] == 'true'):
            if 'amount' in request_json:
                # only consider self.min_amount or larger
                converted_amount = Env.raw_to_amount(int(request_json['amount']))
                if converted_amount >= self.min_amount:
                    # Figure out of this is one of our users
                    link = request_json['block']['link_as_account']
                    account = await Account.filter(address=link).prefetch_related('user').first()
                    if account is None:
                        return web.HTTPOk()
                    # See if this is an internal TX
                    transaction = await Transaction.filter(block_hash=hash).prefetch_related('receiving_user').first()
                    if transaction is not None and transaction.receiving_user is not None:
                        return web.HTTPOk()
                    self.logger.debug(f'Deposit received: {request_json["amount"]} for {account.user.id}')
                    amount_string = f"{Env.raw_to_amount(int(request_json['amount']))} {Env.currency_symbol()}"
                    discord_user = await self.bot.fetch_user(account.user.id)
                    if discord_user is not None:
                        await Messages.send_success_dm(discord_user, f"Your deposit of **{amount_string}** has been received. It will be in your available balance shortly!", header="Deposit Success", footer=f"I only notify you of deposits that are {self.min_amount} {Env.currency_symbol()} or greater.")
        return web.HTTPOk() 
開發者ID:bbedward,項目名稱:graham_discord_bot,代碼行數:35,代碼來源:server.py

示例7: auto_rain_eligible

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def auto_rain_eligible(msg: discord.Message):
        # Ignore if user doesnt have rain role
        has_rain_role = False
        rain_roles = config.Config.instance().get_rain_roles()
        if len(rain_roles) > 0:
            for role in msg.author.roles:
                if role.id in rain_roles:
                    has_rain_role = True
                    break
            if not has_rain_role:
                return

        # Get user OBJ from redis if it exists, else create one
        user_key = f"activity:{msg.guild.id}:{msg.author.id}"
        active_stats = await RedisDB.instance().get(user_key)
        if active_stats is None:
            # Create stats and save
            active_stats = {
                'user_id': msg.author.id,
                'last_msg': datetime.datetime.utcnow().strftime('%m/%d/%Y %H:%M:%S'),
                'msg_count': Constants.RAIN_MSG_REQUIREMENT * 2
            }
            await RedisDB.instance().set(user_key, json.dumps(active_stats), expires=1800)
            return
        else:
            active_stats = json.loads(active_stats)
            if active_stats['msg_count'] < Constants.RAIN_MSG_REQUIREMENT * 2:
                active_stats['msg_count'] = Constants.RAIN_MSG_REQUIREMENT * 2
            active_stats['last_msg'] = datetime.datetime.utcnow().strftime('%m/%d/%Y %H:%M:%S')
            await RedisDB.instance().set(user_key, json.dumps(active_stats), expires=1800) 
開發者ID:bbedward,項目名稱:graham_discord_bot,代碼行數:32,代碼來源:rain.py

示例8: get_active

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def get_active(ctx: Context, excluding: int = 0) -> List[User]:
        """Return a list of active users"""
        msg = ctx.message
        redis = await RedisDB.instance().get_redis()

        # Get all activity stats from DB
        users_list = []
        async for key in redis.iscan(match=f"*activity:{msg.guild.id}*"):
            u = await redis.get(key)
            if u is not None:
                users_list.append(json.loads(u))

        if len(users_list) == 0:
            return []

        # Get IDs that meet requirements
        users_filtered = []
        for u in users_list:
            if u['user_id'] == excluding:
                continue
            elif u['msg_count'] >= Constants.RAIN_MSG_REQUIREMENT:
                users_filtered.append(u['user_id'])

        if len(users_filtered) < 1:
            return []

        # Get only users in our database
        return await User.filter(id__in=users_filtered, frozen=False, tip_banned=False).prefetch_related('account').all() 
開發者ID:bbedward,項目名稱:graham_discord_bot,代碼行數:30,代碼來源:rain.py

示例9: get_replay

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def get_replay(self, id):
        """Description: Send the action to the server for playing out  
        Arguments:  
        * id: The ID of the match to be replayed"""
        self._send(intent=constants.NetworkCommands.replay.value, replay_id=id)
        try:
            status, replay = rapidjson.loads(
                str(gzip.decompress(self.ws_.recv()), "utf-8"))
        except ValueError:
            raise Exception(constants.Exceptions.replay_notfound.value)
        if status == constants.NetworkCommands.status_ok.value:
            return replay
        else:
            raise Exception(constants.Exceptions.replay_notfound.value) 
開發者ID:MultiAgentLearning,項目名稱:playground,代碼行數:16,代碼來源:network.py

示例10: _recieve

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def _recieve(self):
        self.lock.acquire()
        try:
            message_recieved = self.ws_.recv()
        except:
            if not self.ws_.connected:
                raise Exception(constants.Exceptions.net_server_closed.value)
            else:
                raise Exception(constants.Exceptions.net_invalid_response.value)
        finally:
            self.lock.release()
        try:
            return rapidjson.loads(message_recieved)
        except:
            raise Exception(constants.Exceptions.net_invalid_response.value) 
開發者ID:MultiAgentLearning,項目名稱:playground,代碼行數:17,代碼來源:network.py

示例11: ws_handler

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def ws_handler(websocket, pth=None):  # pylint: disable=unused-argument
    """Handle the messages recieved by WebSocket (pth is not required but still\
returned by the 'websockets' library)"""
    try:
        async for message in websocket:
            try:
                await message_parse(rapidjson.loads(message), websocket)
            except:
                pass
    except websockets.exceptions.ConnectionClosed:
        pass 
開發者ID:MultiAgentLearning,項目名稱:playground,代碼行數:13,代碼來源:network.py

示例12: get_query_params

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def get_query_params(self, query_id: str) -> dict:
        query_params_str = self.redis_client.get(query_id)
        if query_params_str is None:
            raise UnkownQueryIdError(f"Unknown query_id: '{query_id}'")
        return rapidjson.loads(query_params_str) 
開發者ID:Flowminder,項目名稱:FlowKit,代碼行數:7,代碼來源:query_info_lookup.py

示例13: deserialize

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def deserialize(data):
    """Deserialize a JSON formatted string into a dict.

        Args:
            data (str): JSON formatted string.

        Returns:
            dict: dict resulting from the serialization of a JSON formatted
            string.
    """
    return rapidjson.loads(data) 
開發者ID:bigchaindb,項目名稱:bigchaindb,代碼行數:13,代碼來源:utils.py

示例14: json_loads

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def json_loads(x):
    return json.loads(x) 
開發者ID:qsniyg,項目名稱:rssit,代碼行數:4,代碼來源:util.py

示例15: dolartoday_bolivar

# 需要導入模塊: import rapidjson [as 別名]
# 或者: from rapidjson import loads [as 別名]
def dolartoday_bolivar():
    response = json.loads(requests.get(url=dolartoday_price).text)
    if "USD" not in response:
        print("Invalid response " + str(response))
        return
    bolivarprice = response['USD']['localbitcoin_ref']
    if bolivarprice is None:
        print("Couldn't find localbitcoin_ref price")
        return
    print(rdata.hset("prices", "dolartoday:usd-ves", bolivarprice),
          "DolarToday USD-VES", bolivarprice) 
開發者ID:appditto,項目名稱:natrium-wallet-server,代碼行數:13,代碼來源:vesprice.py


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