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


Python objectid.ObjectId方法代碼示例

本文整理匯總了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) 
開發者ID:broadinstitute,項目名稱:single_cell_portal,代碼行數:27,代碼來源:manage_study.py

示例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'] 
開發者ID:vijos,項目名稱:vj4,代碼行數:20,代碼來源:document.py

示例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']) 
開發者ID:vijos,項目名稱:vj4,代碼行數:20,代碼來源:record.py

示例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) 
開發者ID:vijos,項目名稱:vj4,代碼行數:25,代碼來源:contest.py

示例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 
開發者ID:vijos,項目名稱:vj4,代碼行數:25,代碼來源:contest.py

示例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 
開發者ID:vijos,項目名稱:vj4,代碼行數:19,代碼來源:contest.py

示例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'])) 
開發者ID:vijos,項目名稱:vj4,代碼行數:20,代碼來源:homework.py

示例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)) 
開發者ID:vijos,項目名稱:vj4,代碼行數:22,代碼來源:homework.py

示例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 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:6,代碼來源:models.py

示例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}}) 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:7,代碼來源:models.py

示例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}}) 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:7,代碼來源:models.py

示例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 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:9,代碼來源:models.py

示例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}})

    #修改昵稱 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:16,代碼來源:models.py

示例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}})

    #修改手機號 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:8,代碼來源:models.py

示例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}})

    #修改用戶姓名 
開發者ID:iHealth-ecnu,項目名稱:iHealth_site,代碼行數:8,代碼來源:models.py


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