本文整理匯總了Python中ujson.loads方法的典型用法代碼示例。如果您正苦於以下問題:Python ujson.loads方法的具體用法?Python ujson.loads怎麽用?Python ujson.loads使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ujson
的用法示例。
在下文中一共展示了ujson.loads方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: update_position
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def update_position(self):
for _, pos in self.__shares.items():
inst = Instrument.objects.filter(
exchange=pos['ExchangeID'],
product_code=re.findall('[A-Za-z]+', pos['InstrumentID'])[0]).first()
tick = json.loads(self.redis_client.get(pos['InstrumentID']))
if pos['Direction'] == ApiStruct.D_Buy:
profit = Decimal(tick['LastPrice']) - Decimal(pos['OpenPrice'])
else:
profit = Decimal(pos['OpenPrice']) - Decimal(tick['LastPrice'])
profit = profit * Decimal(pos['Volume']) * inst.volume_multiple
Trade.objects.update_or_create(
broker=self.__broker, strategy=self.__strategy, instrument=inst,
code=pos['InstrumentID'],
direction=DirectionType.LONG if pos['Direction'] == ApiStruct.D_Buy else DirectionType.SHORT,
close_time__isnull=True,
defaults={
'open_time': datetime.datetime.strptime(
pos['OpenDate']+'09', '%Y%m%d%H').replace(tzinfo=pytz.FixedOffset(480)),
'shares': pos['Volume'], 'filled_shares': pos['Volume'],
'avg_entry_price': Decimal(pos['OpenPrice']),
'cost': pos['Volume'] * Decimal(pos['OpenPrice']) * inst.fee_money *
inst.volume_multiple + pos['Volume'] * inst.fee_volume,
'profit': profit, 'frozen_margin': Decimal(pos['Margin'])})
示例2: update_inst_fee
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def update_inst_fee(self, inst: Instrument):
"""
更新每一個合約的手續費
"""
try:
fee = (await self.query('InstrumentCommissionRate', InstrumentID=inst.main_code))
if fee:
fee = fee[0]
inst.fee_money = Decimal(fee['CloseRatioByMoney'])
inst.fee_volume = Decimal(fee['CloseRatioByVolume'])
tick = json.loads(self.redis_client.get(inst.main_code))
inst.up_limit_ratio = (Decimal(tick['UpperLimitPrice']) -
Decimal(tick['PreSettlementPrice'])) / Decimal(tick['PreSettlementPrice'])
inst.up_limit_ratio = round(inst.up_limit_ratio, 3)
inst.down_limit_ratio = (Decimal(tick['PreSettlementPrice']) -
Decimal(tick['LowerLimitPrice'])) / Decimal(tick['PreSettlementPrice'])
inst.down_limit_ratio = round(inst.down_limit_ratio, 3)
inst.save(update_fields=['fee_money', 'fee_volume', 'margin_rate',
'up_limit_ratio', 'down_limit_ratio'])
except Exception as e:
logger.error('update_inst_fee failed: %s', e, exc_info=True)
示例3: load_data
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def load_data(args, filename, skip_no_answer=False):
"""Load examples from preprocessed file.
One example per line, JSON encoded.
"""
# Load JSON lines
with open(filename) as f:
examples = [json.loads(line) for line in f]
# Make case insensitive?
if args.uncased_question or args.uncased_doc:
for ex in examples:
if args.uncased_question:
ex['question'] = [w.lower() for w in ex['question']]
ex['question_char'] = [w.lower() for w in ex['question_char']]
if args.uncased_doc:
ex['document'] = [w.lower() for w in ex['document']]
ex['document_char'] = [w.lower() for w in ex['document_char']]
# Skip unparsed (start/end) examples
if skip_no_answer:
examples = [ex for ex in examples if len(ex['answers']) > 0]
return examples
示例4: _thread
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def _thread(self, obj_key):
article_list = []
with NamedTemporaryFile(mode='w+b', dir='/home/ubuntu/temp2/') as packet_temp:
s3client.download_fileobj('periodista', obj_key, packet_temp)
packet_temp.seek(0)
with open(packet_temp.name, 'r') as fin:
for l in fin:
article = json.loads(l)
# Preprocessing could go here
_fix_notfound_authors(article)
_fix_photos(article)
article_list.append(article)
return article_list
示例5: _iterate_through_archivedotorg
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def _iterate_through_archivedotorg(bucket_name):
with NamedTemporaryFile(mode='w+b', dir='/home/ubuntu/temp2/') as packet_temp:
s3client.download_fileobj(bucket_name, 'archivedotorg.jsonl', packet_temp)
packet_temp.seek(0)
with open(packet_temp.name, 'r') as fin:
for l in fin:
article = json.loads(l)
article['split'] = _get_split(article['domain'])
if article['split'] == 'ignore':
article['split'] = 'train'
# Preprocessing could go here
_fix_notfound_authors(article)
_fix_photos(article)
if _is_definitely_unique(article):
yield article
示例6: article_iterator
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def article_iterator(encoder, final_desired_size=1025):
""" Iterate through the provided filename + tokenize"""
assert os.path.exists(args.input_fn)
with open(args.input_fn, 'r') as f:
for l_no, l in enumerate(f):
if l_no % args.num_folds == args.fold:
article = json.loads(l)
article['input_ids'] = tokenize_for_grover_training(encoder, article, desired_size=final_desired_size,
unconditional_prob=.35)
article['inst_index'] = (l_no // args.num_folds)
if article['inst_index'] < 100:
print('---\nINPUT{}. {}\n---\nTokens: {}\n'.format(article['inst_index'],
detokenize(encoder, article['input_ids']),
article['input_ids']
), flush=True)
if len(article['input_ids']) == 0:
continue
yield article
示例7: iter_question
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def iter_question(filename, file_map):
with open(filename, "r") as f:
for line in f:
item = json.loads(line.strip())
question = item['question']
question_id = item['question_id']
answer = XQAAnswer([ans.strip() for ans in item['answers']])
docs = []
for (subdir, filename) in item['docs']:
title = filename[:filename.rfind('.')] if filename.rfind('.') != -1 else filename
filepath = join(subdir, title)
file_map[title] = filepath
docs.append(XQADoc(title))
yield XQAQuestion(question, question_id, answer, docs)
示例8: _get_bin
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def _get_bin(self, key):
'''
Returns a binned dictionary based on redis zscore
@return: The sorted dict
'''
# keys based on score
sortedDict = {}
# this doesnt return them in order, need to bin first
for item in self.redis_conn.zscan_iter(key):
my_item = ujson.loads(item[0])
# score is negated in redis
my_score = -item[1]
if my_score not in sortedDict:
sortedDict[my_score] = []
sortedDict[my_score].append(my_item)
return sortedDict
示例9: _mini_purge
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def _mini_purge(self, spiderid, appid, crawlid):
'''
Actually purges the crawlid from the queue
@param spiderid: the spider id
@param appid: the app id
@param crawlid: the crawl id
@return: The number of requests purged
'''
total_purged = 0
match_string = '{sid}:*:queue'.format(sid=spiderid)
# using scan for speed vs keys
for key in self.redis_conn.scan_iter(match=match_string):
for item in self.redis_conn.zscan_iter(key):
item_key = item[0]
item = ujson.loads(item_key)
if 'meta' in item:
item = item['meta']
if item['appid'] == appid and item['crawlid'] == crawlid:
self.redis_conn.zrem(key, item_key)
total_purged = total_purged + 1
return total_purged
示例10: post
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def post(self):
if not self.request.body:
self.set_status(401)
self.finish('error')
return
json = ujson.loads(self.request.body)
print(json)
if 'path' not in json:
self.set_status(401)
self.finish('error')
return
path = json.pop('path')
if not path or not json.get('title', None) or not json.get('authors', None) or not json.get('tags', None) or not json.get('tldr', None):
self.set_status(401)
self.finish('error')
return
kp = nb_to_kp(path, **json)
print(kp)
self.finish('test')
示例11: getguild
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def getguild(self, request: web.Request):
guild = int(request.match_info['guild'])
req = f"""SELECT info FROM guilddata WHERE UUID = $1"""
async with self.bot.db._conn.acquire() as connection:
response = await connection.fetchval(req, guild)
if response:
data = json.loads(response)
fdata = data
if request.match_info['tail']:
for item in request.match_info['tail'].split("/"):
if not item:
continue
try:
key = unquote(item)
if isinstance(fdata, list):
key = int(key)
fdata = fdata[key]
except:
raise web.HTTPNotFound()
return web.json_response(fdata)
raise web.HTTPForbidden()
# @server.route("/", methods=["GET"])
示例12: __init__
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def __init__(self, file_name, user_id):
"""
Reads data from file, loads it as JSON
"""
with open(file_name, 'r') as self.opened_file:
self.data = self.opened_file.read()
self.user = user_id
self.data = ujson.loads(self.data)
self.urls = dict() # Keeps track of all the urls in the import file, used when adding to db
self.tags_dict = dict() # Store tag objects for imported bookmarks
self.tags_set = set() # Keeps track of all the tags in the import file
self.check_duplicates = dict() # Store all current bookmarks for the user
self.check_duplicates_query = Bookmark.query.filter(Bookmark.user == self.user,
Bookmark.deleted == False).all()
for x in self.check_duplicates_query:
self.check_duplicates[x.main_url] = x # Add bookmark object to dict
self.html_parser = HTMLParser.HTMLParser()
self.valid_url = re.compile(
r'^(?:[a-z0-9\.\-]*)://'
r'(?:(?:[A-Z0-9](?:[A-Z0-9-]{0,61}[A-Z0-9])?\.)+(?:[A-Z]{2,6}\.?|[A-Z0-9-]{2,}(?<!-)\.?)|'
r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}|'
r'\[?[A-F0-9]*:[A-F0-9:]+\]?)'
r'(?::\d+)?'
r'(?:/?|[/?]\S+)$', re.IGNORECASE) # We only want valid URLs in the database
示例13: _listen
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def _listen(self):
pubsub = self.SR.pubsub(ignore_subscribe_messages=True)
pubsub.psubscribe('mm-engine-status.*')
while pubsub.subscribed:
response = pubsub.get_message(timeout=30.0)
if response is None:
continue
if not bool(self._signal.receivers):
LOG.info('no receivers')
continue
data = json.loads(response['data'])
source = data.pop('source', '<unknown-node>')
self._signal.send(source, data=data)
示例14: test_unpack
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def test_unpack(data_dir, heka_format, try_snappy, strict, expected_count,
expected_exception):
count = 0
threw_exception = False
filename = "{}/test_{}.heka".format(data_dir, heka_format)
with open(filename, "rb") as o:
if "gzip" in heka_format:
o = streaming_gzip_wrapper(o)
try:
for r, b in message_parser.unpack(o, try_snappy=try_snappy, strict=strict):
j = json.loads(r.message.payload)
assert count == j["seq"]
count += 1
except DecodeError:
threw_exception = True
assert count == expected_count
assert threw_exception == expected_exception
示例15: _fetch_histograms_definition
# 需要導入模塊: import ujson [as 別名]
# 或者: from ujson import loads [as 別名]
def _fetch_histograms_definition(url):
cached = definition_cache.get(url, None)
if cached is None:
definition = requests.get(url).content
# see bug 920169
definition = definition.replace(b'"JS::gcreason::NUM_TELEMETRY_REASONS"', b"101")
definition = definition.replace(b'"mozilla::StartupTimeline::MAX_EVENT_ID"', b"12")
definition = definition.replace(b'"80 + 1"', b"81")
parsed = json.loads(definition)
parsed.update(histogram_exceptions)
definition_cache[url] = parsed
return parsed
else:
return cached