本文整理匯總了Python中bson.objectid.ObjectId方法的典型用法代碼示例。如果您正苦於以下問題:Python objectid.ObjectId方法的具體用法?Python objectid.ObjectId怎麽用?Python objectid.ObjectId使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類bson.objectid
的用法示例。
在下文中一共展示了objectid.ObjectId方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: validate_metadata_file
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def validate_metadata_file(metadata_path):
study_name = get_parsed_args().study_name
dry_run = get_parsed_args().dry_run
verbose = get_parsed_args().verbose
study_accession_res =get_connection().get_study_attribute(
study_name=study_name,
attribute='accession',
dry_run=dry_run)
# Needed dummy values for CellMetadata
study_file = ObjectId('addedfeed000000000000000')
study_file_id = ObjectId('addedfeed000000000000001')
if succeeded(study_accession_res):
if verbose:
print(f'Study accession {study_accession_res} retrieved for {study_name}')
study_accession = study_accession_res.get('study_attribute')
metadata = CellMetadata(metadata_path, study_file, study_file_id, study_accession=str(study_accession))
convention_res = get_connection().do_get(command=get_api_base() + 'metadata_schemas/alexandria_convention/latest/json',dry_run=dry_run)
if succeeded(convention_res ):
if verbose:
print(f'Retreieved file for latest metdata convention')
convention = convention_res["response"].json()
validate_input_metadata(metadata, convention)
serialize_issues(metadata)
report_issues(metadata)
exit_if_errors(metadata)
示例2: add
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def add(domain_id: str, content: str, owner_uid: int,
doc_type: int, doc_id: convert_doc_id = None,
parent_doc_type: int = None, parent_doc_id: convert_doc_id = None, **kwargs):
"""Add a document. Returns the document id."""
obj_id = objectid.ObjectId()
coll = db.coll('document')
doc = {'_id': obj_id,
'content': content,
'owner_uid': owner_uid,
'domain_id': domain_id,
'doc_type': doc_type,
'doc_id': doc_id or obj_id,
**kwargs}
if parent_doc_type or parent_doc_id:
assert parent_doc_type and parent_doc_id
doc['parent_doc_type'], doc['parent_doc_id'] = parent_doc_type, parent_doc_id
await coll.insert_one(doc)
return doc['doc_id']
示例3: rejudge
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def rejudge(record_id: objectid.ObjectId, enqueue: bool=True):
coll = db.coll('record')
doc = await coll.find_one_and_update(filter={'_id': record_id},
update={'$unset': {'judge_uid': '',
'judge_token': '',
'judge_at': '',
'compiler_texts': '',
'judge_texts': '',
'cases': ''},
'$set': {'status': constant.record.STATUS_WAITING,
'score': 0,
'time_ms': 0,
'memory_kb': 0,
'rejudged': True}},
return_document=ReturnDocument.AFTER)
bus.publish_throttle('record_change', doc, doc['_id'])
if enqueue:
await queue.publish('judge', rid=doc['_id'])
示例4: edit
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def edit(domain_id: str, doc_type: int, tid: objectid.ObjectId, **kwargs):
if doc_type not in [document.TYPE_CONTEST, document.TYPE_HOMEWORK]:
raise error.InvalidArgumentError('doc_type')
if 'title' in kwargs:
validator.check_title(kwargs['title'])
if 'content' in kwargs:
validator.check_content(kwargs['content'])
if 'rule' in kwargs:
if doc_type == document.TYPE_CONTEST:
if kwargs['rule'] not in constant.contest.CONTEST_RULES:
raise error.ValidationError('rule')
elif doc_type == document.TYPE_HOMEWORK:
if kwargs['rule'] not in constant.contest.HOMEWORK_RULES:
raise error.ValidationError('rule')
if 'begin_at' in kwargs and 'end_at' in kwargs:
if kwargs['begin_at'] >= kwargs['end_at']:
raise error.ValidationError('begin_at', 'end_at')
if 'penalty_since' in kwargs:
if 'begin_at' in kwargs and kwargs['penalty_since'] < kwargs['begin_at']:
raise error.ValidationError('penalty_since', 'begin_at')
if 'end_at' in kwargs and kwargs['penalty_since'] > kwargs['end_at']:
raise error.ValidationError('penalty_since', 'end_at')
return await document.set(domain_id, doc_type, tid, **kwargs)
示例5: update_status
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def update_status(domain_id: str, doc_type: int, tid: objectid.ObjectId, uid: int,
rid: objectid.ObjectId, pid: document.convert_doc_id,
accept: bool, score: int):
"""This method returns None when the modification has been superseded by a parallel operation."""
if doc_type not in [document.TYPE_CONTEST, document.TYPE_HOMEWORK]:
raise error.InvalidArgumentError('doc_type')
tdoc = await document.get(domain_id, doc_type, tid)
tsdoc = await document.rev_push_status(
domain_id, tdoc['doc_type'], tdoc['doc_id'], uid,
'journal', {'rid': rid, 'pid': pid, 'accept': accept, 'score': score})
if 'attend' not in tsdoc or not tsdoc['attend']:
if tdoc['doc_type'] == document.TYPE_CONTEST:
raise error.ContestNotAttendedError(domain_id, tid, uid)
elif tdoc['doc_type'] == document.TYPE_HOMEWORK:
raise error.HomeworkNotAttendedError(domain_id, tid, uid)
else:
raise error.InvalidArgumentError('doc_type')
journal = _get_status_journal(tsdoc)
stats = RULES[tdoc['rule']].stat_func(tdoc, journal)
tsdoc = await document.rev_set_status(domain_id, tdoc['doc_type'], tid, uid, tsdoc['rev'],
journal=journal, **stats)
return tsdoc
示例6: get_scoreboard
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def get_scoreboard(self, doc_type: int, tid: objectid.ObjectId, is_export: bool=False):
if doc_type not in [document.TYPE_CONTEST, document.TYPE_HOMEWORK]:
raise error.InvalidArgumentError('doc_type')
tdoc, tsdocs = await get_and_list_status(self.domain_id, doc_type, tid)
if not self.can_show_scoreboard(tdoc):
if doc_type == document.TYPE_CONTEST:
raise error.ContestScoreboardHiddenError(self.domain_id, tid)
elif doc_type == document.TYPE_HOMEWORK:
raise error.HomeworkScoreboardHiddenError(self.domain_id, tid)
udict, dudict, pdict = await asyncio.gather(
user.get_dict([tsdoc['uid'] for tsdoc in tsdocs]),
domain.get_dict_user_by_uid(self.domain_id, [tsdoc['uid'] for tsdoc in tsdocs]),
problem.get_dict(self.domain_id, tdoc['pids']))
ranked_tsdocs = RULES[tdoc['rule']].rank_func(tsdocs)
rows = RULES[tdoc['rule']].scoreboard_func(is_export, self.translate, tdoc,
ranked_tsdocs, udict, dudict, pdict)
return tdoc, rows, udict
示例7: get
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def get(self, *, tid: objectid.ObjectId):
tdoc, tsdocs = await contest.get_and_list_status(self.domain_id, document.TYPE_HOMEWORK, tid)
rnames = {}
for tsdoc in tsdocs:
for pdetail in tsdoc.get('detail', []):
rnames[pdetail['rid']] = 'U{}_P{}_R{}'.format(tsdoc['uid'], pdetail['pid'], pdetail['rid'])
output_buffer = io.BytesIO()
zip_file = zipfile.ZipFile(output_buffer, 'a', zipfile.ZIP_DEFLATED)
rdocs = record.get_multi(get_hidden=True, _id={'$in': list(rnames.keys())})
async for rdoc in rdocs:
zip_file.writestr(rnames[rdoc['_id']] + '.' + rdoc['lang'], rdoc['code'])
# mark all files as created in Windows :p
for zfile in zip_file.filelist:
zfile.create_system = 0
zip_file.close()
await self.binary(output_buffer.getvalue(), 'application/zip',
file_name='{}.zip'.format(tdoc['title']))
示例8: post
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def post(self, *, tid: objectid.ObjectId, pid: document.convert_doc_id,
lang: str, code: str):
tdoc, pdoc = await asyncio.gather(contest.get(self.domain_id, document.TYPE_HOMEWORK, tid),
problem.get(self.domain_id, pid))
tsdoc = await contest.get_status(self.domain_id, document.TYPE_HOMEWORK, tdoc['doc_id'], self.user['_id'])
if not tsdoc or tsdoc.get('attend') != 1:
raise error.HomeworkNotAttendedError(tdoc['doc_id'])
if not self.is_ongoing(tdoc):
raise error.HomeworkNotLiveError(tdoc['doc_id'])
if pid not in tdoc['pids']:
raise error.ProblemNotFoundError(self.domain_id, pid, tdoc['doc_id'])
rid = await record.add(self.domain_id, pdoc['doc_id'], constant.record.TYPE_SUBMISSION,
self.user['_id'], lang, code,
ttype=document.TYPE_HOMEWORK, tid=tdoc['doc_id'], hidden=True)
await contest.update_status(self.domain_id, document.TYPE_HOMEWORK, tdoc['doc_id'], self.user['_id'],
rid, pdoc['doc_id'], False, 0)
if not self.can_show_record(tdoc):
self.json_or_redirect(self.reverse_url('homework_detail', tid=tdoc['doc_id']))
else:
self.json_or_redirect(self.reverse_url('record_detail', rid=rid))
示例9: find_one
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def find_one(self,id):
'''獲取指定數據'''
article = self.articles.find_one({"_id": ObjectId(id)})
return article
示例10: updateRead
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def updateRead(self,id=None,cnt=1):
'''閱讀量+1'''
if id == None:
raise Exception,'請提供 id 參數!'
self.articles.update_one({'_id':ObjectId(id)},{'$inc':{'read':cnt}})
示例11: updateUpvote
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def updateUpvote(self,id=None):
'''點讚接口'''
if id == None:
raise Exception,'請提供 id 參數!'
self.articles.update_one({'_id':ObjectId(id)},{'$inc':{'upvote':1}})
示例12: find_label
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def find_label(self, id):
'''獲取用戶對應的labels'''
user = self.users.find_one({"_id": ObjectId(id)})
if user.has_key('labels'):
return user['labels']
else: #用戶沒有label
return None
示例13: update_label
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def update_label(self, id, label, value):
'''更新labels中label的值'''
#沒有labels的用戶首先設置label
self.insert_label(id)
#首先找到對應用戶的labels
user = self.users.find_one({"_id": ObjectId(id)})
cur_labels = user['labels']
if cur_labels.has_key(label):
cur_labels[label] = cur_labels[label] + value
else: #新增對應label
cur_labels[label] = value
self.users.update_one({"_id": ObjectId(id)}, {'$set': {'labels':cur_labels}})
#修改昵稱
示例14: changeNickname
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def changeNickname(self,id=None,newName=None):
if id == None or newName == None:
raise Exception,'請提供 id 和昵稱完整參數!'
self.users.update_one({'_id':ObjectId(id)},{'$set':{'nickname':newName}})
#修改手機號
示例15: changePhone
# 需要導入模塊: from bson import objectid [as 別名]
# 或者: from bson.objectid import ObjectId [as 別名]
def changePhone(self,id=None,newPhone=None):
if id == None or newPhone == None:
raise Exception,'請提供 id 和手機號完整參數!'
self.users.update_one({'_id':ObjectId(id)},{'$set':{'phone':newPhone}})
#修改用戶姓名