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


Python bisect.insort_right方法代碼示例

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


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

示例1: insort_right_rev

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def insort_right_rev(alist, new_element, low=0, high=None):
    """Similar to bisect.insort_right but for reverse sorted lists

    This code is similar to the Python code found in Lib/bisect.py.
    We simply change the comparison from 'less than' to 'greater than'.
    """

    if low < 0:
        raise ValueError('low must be non-negative')
    if high is None:
        high = len(alist)
    while low < high:
        middle = (low + high) // 2
        if new_element > alist[middle]:
            high = middle
        else:
            low = middle + 1
    alist.insert(low, new_element) 
開發者ID:LuciferJack,項目名稱:python-mysql-pool,代碼行數:20,代碼來源:caching.py

示例2: trigger

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def trigger(self):
        """
        觸發一次定時器

        :return: 如果到時觸發了一個定時器,則返回這個定時器的附屬參數。否則返回None
        :rtype: str
        """

        with self._lock:
            if len(self._timer_queue) > 0 and self._timer_queue[0].current <= int(time.time()):
                top_timer = self._timer_queue.pop(0)
                param = top_timer.param
                top_timer.next()
                bisect.insort_right(self._timer_queue, top_timer)
                return param
            else:
                return None 
開發者ID:baidu,項目名稱:ARK,代碼行數:19,代碼來源:cron_sensor.py

示例3: addRange

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def addRange(self, ipmask):
        ip, mask = ipmask
        ipmask = (ip & mask, mask)

        # See if this range is already covered.
        if self.containsRange(ipmask):
            return

        # Delete any existing ranges that are covered by this new range.
        deletes = []
        for i, old_ipmask in enumerate(self.nets):
            if IsSubsetOf(old_ipmask, ipmask):
                deletes.append(i)
        for i in reversed(deletes):
            del self.nets[i]

        # Insert the new range
        bisect.insort_right(self.nets, ipmask) 
開發者ID:ffledgling,項目名稱:dtella,代碼行數:20,代碼來源:ipv4.py

示例4: add_partition

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def add_partition(self, key, group):
        """Add sharding information for a group"""
        if self.shard_type == 'RANGE':
            key = int(key)
        elif self.shard_type == 'RANGE_DATETIME':
            try:
                if ':' in key:
                    key = datetime.strptime(key, "%Y-%m-%d %H:%M:%S")
                else:
                    key = datetime.strptime(key, "%Y-%m-%d").date()
            except:
                raise ValueError(
                    "RANGE_DATETIME key could not be parsed, was: {0}".format(
                        key
                    ))
        elif self.shard_type == 'RANGE_STRING':
            pass
        elif self.shard_type == "HASH":
            pass
        else:
            raise ValueError("Unsupported sharding type {0}".format(
                self.shard_type
            ))
        self.partitioning[key] = {
            'group': group,
        }
        self.reset_ttl()
        bisect.insort_right(self.keys, key)
        insort_right_rev(self.keys_reversed, key) 
開發者ID:LuciferJack,項目名稱:python-mysql-pool,代碼行數:31,代碼來源:caching.py

示例5: set_tab

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def set_tab(self): # <ESC>H
        '''Sets a tab at the current position.'''
        r, c = self.cursor()
        bisect.insort_right(self._tabs, c) 
開發者ID:kdart,項目名稱:pycopia,代碼行數:6,代碼來源:terminal.py

示例6: register

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def register(
        self, what, when, func, on_tags, order, is_formatter=False, always=False
    ):
        """Register the given Hook for later execution"""
        if inspect.isgeneratorfunction(func):
            # the registered function is a generator hook
            hook_impl = GeneratorHookImpl(
                what, func, on_tags, order, is_formatter, always
            )

            if (
                hook_impl in self._hooks["before"][what]
                and hook_impl in self._hooks["after"][what]
            ):
                # NOTE: allow a Hook Implementation to be registered multiple times.
                #       This can happend when one hook module imports another in the same
                #       RADISH_BASEDIR.
                return

            # insert the HookImpl in the order given by ``order``.
            bisect.insort_right(self._hooks["before"][what], hook_impl)
            bisect.insort_right(self._hooks["after"][what], hook_impl)
        else:
            # we have regular hook
            hook_impl = HookImpl(what, when, func, on_tags, order, is_formatter, always)

            if hook_impl in self._hooks[when][what]:
                # NOTE: allow a Hook Implementation to be registered multiple times.
                #       This can happend when one hook module imports another in the same
                #       RADISH_BASEDIR.
                return

            # insert the HookImpl in the order given by ``order``.
            bisect.insort_right(self._hooks[when][what], hook_impl) 
開發者ID:radish-bdd,項目名稱:radish,代碼行數:36,代碼來源:hookregistry.py

示例7: test_keyword_args

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_keyword_args(self):
        data = [10, 20, 30, 40, 50]
        self.assertEqual(bisect_left(a=data, x=25, lo=1, hi=3), 2)
        self.assertEqual(bisect_right(a=data, x=25, lo=1, hi=3), 2)
        self.assertEqual(bisect(a=data, x=25, lo=1, hi=3), 2)
        insort_left(a=data, x=25, lo=1, hi=3)
        insort_right(a=data, x=25, lo=1, hi=3)
        insort(a=data, x=25, lo=1, hi=3)
        self.assertEqual(data, [10, 20, 25, 25, 25, 30, 40, 50])

#============================================================================== 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:13,代碼來源:test_bisect.py

示例8: test_vsBuiltinSort

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_vsBuiltinSort(self, n=500):
        from random import choice
        for insorted in (list(), UserList()):
            for i in xrange(n):
                digit = choice("0123456789")
                if digit in "02468":
                    f = insort_left
                else:
                    f = insort_right
                f(insorted, digit)
        self.assertEqual(sorted(insorted), insorted) 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:13,代碼來源:test_bisect.py

示例9: test_backcompatibility

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_backcompatibility(self):
        self.assertEqual(insort, insort_right)

#============================================================================== 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:6,代碼來源:test_bisect.py

示例10: test_non_sequence

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_non_sequence(self):
        for f in (bisect_left, bisect_right, insort_left, insort_right):
            self.assertRaises(TypeError, f, 10, 10) 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:5,代碼來源:test_bisect.py

示例11: test_len_only

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_len_only(self):
        for f in (bisect_left, bisect_right, insort_left, insort_right):
            self.assertRaises(AttributeError, f, LenOnly(), 10) 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:5,代碼來源:test_bisect.py

示例12: test_cmp_err

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_cmp_err(self):
        seq = [CmpErr(), CmpErr(), CmpErr()]
        for f in (bisect_left, bisect_right, insort_left, insort_right):
            self.assertRaises(ZeroDivisionError, f, seq, 10) 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:6,代碼來源:test_bisect.py

示例13: test_arg_parsing

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def test_arg_parsing(self):
        for f in (bisect_left, bisect_right, insort_left, insort_right):
            self.assertRaises(TypeError, f, 10)

#============================================================================== 
開發者ID:ofermend,項目名稱:medicare-demo,代碼行數:7,代碼來源:test_bisect.py

示例14: add_domain

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def add_domain(self, domain: Any, feature_name: str, subtype: str = "") -> None:
        """ Adds a domain to the current set.

            Arguments:
                domain: the domain to add, this should be a HMMResult-like object
            (see: antismash.common.hmmscan_refinement.HMMResult).
                feature_name: the name of the matching AntismashDomain feature
                              in the same record as this qualifier
                subtype: a specific subtype of the domain type, if any

            Returns:
                None
        """
        assert not isinstance(domain, str)
        if subtype:
            assert domain.hit_id == "PKS_KS", domain.hit_id
        if domain.hit_id == "PKS_AT":
            self.at_counter += 1
            suffix = "_AT%d" % self.at_counter
        elif domain.hit_id == "PKS_KR":
            self.kr_counter += 1
            suffix = "_KR%d" % self.kr_counter
        elif domain.hit_id == "CAL_domain":
            self.cal_counter += 1
            suffix = "_CAL%d" % self.cal_counter
        elif domain.hit_id in ["AMP-binding", "A-OX"]:
            self.a_counter += 1
            suffix = "_A%d" % self.a_counter
        elif domain.hit_id == "PKS_KS":
            self.ks_counter += 1
            suffix = "_KS%d" % self.ks_counter
        else:
            self.other_counter += 1
            suffix = "_OTHER%d" % self.other_counter

        new = NRPSPKSQualifier.Domain(domain.hit_id, suffix,
                                      domain.query_start, domain.query_end,
                                      domain.evalue, domain.bitscore, feature_name, subtype)
        bisect.insort_right(self._domains, new)
        # update the domain name list
        self._domain_names = [domain.name for domain in self._domains] 
開發者ID:antismash,項目名稱:antismash,代碼行數:43,代碼來源:nrps_pks.py

示例15: bookmarkAdd

# 需要導入模塊: import bisect [as 別名]
# 或者: from bisect import insort_right [as 別名]
def bookmarkAdd(self):
        """Adds a bookmark at the cursor's location. If multiple lines are
        selected, all existing bookmarks in those lines are overwritten with the
        new bookmark.

        Args:
          None.

        Returns:
          None.
        """
        newBookmark = self.dataToBookmark()
        self.bookmarkRemove()
        bisect.insort_right(self.bookmarks, newBookmark) 
開發者ID:google,項目名稱:ci_edit,代碼行數:16,代碼來源:actions.py


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