Python collections.OrderedDict.fromkeys() Examples
The following are 30
code examples of collections.OrderedDict.fromkeys().
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example.
You may also want to check out all available functions/classes of the module
collections.OrderedDict
, or try the search function
.
Example #1
Source File: util.py From pycasbin with Apache License 2.0 | 6 votes |
def array_remove_duplicates(s): """removes any duplicated elements in a string array.""" return list(OrderedDict.fromkeys(s))
Example #2
Source File: field.py From meshed-memory-transformer with BSD 3-Clause "New" or "Revised" License | 6 votes |
def build_vocab(self, *args, **kwargs): counter = Counter() sources = [] for arg in args: if isinstance(arg, Dataset): sources += [getattr(arg, name) for name, field in arg.fields.items() if field is self] else: sources.append(arg) for data in sources: for x in data: x = self.preprocess(x) try: counter.update(x) except TypeError: counter.update(chain.from_iterable(x)) specials = list(OrderedDict.fromkeys([ tok for tok in [self.unk_token, self.pad_token, self.init_token, self.eos_token] if tok is not None])) self.vocab = self.vocab_cls(counter, specials=specials, **kwargs)
Example #3
Source File: category.py From GraphicDesignPatternByPython with MIT License | 6 votes |
def update(self, data): """Maps new values to integer identifiers. Parameters ---------- data: iterable sequence of string values Raises ------ TypeError If the value in data is not a string, unicode, bytes type """ data = np.atleast_1d(np.array(data, dtype=object)) for val in OrderedDict.fromkeys(data): if not isinstance(val, (str, bytes)): raise TypeError("{val!r} is not a string".format(val=val)) if val not in self._mapping: self._mapping[val] = next(self._counter) # Connects the convertor to matplotlib
Example #4
Source File: utils.py From musicbox with MIT License | 5 votes |
def uniq(arr): return list(OrderedDict.fromkeys(arr).keys())
Example #5
Source File: main.py From postie with MIT License | 5 votes |
def dict_template(self): """ Return an ordered dict with all the headers from csv file. """ headers = self.csv_content[0] template_var_list = [each.strip() for each in headers][1:] return OrderedDict.fromkeys(template_var_list)
Example #6
Source File: test_collections.py From Fluid-Designer with GNU General Public License v3.0 | 5 votes |
def test_fromkeys(self): OrderedDict = self.OrderedDict od = OrderedDict.fromkeys('abc') self.assertEqual(list(od.items()), [(c, None) for c in 'abc']) od = OrderedDict.fromkeys('abc', value=None) self.assertEqual(list(od.items()), [(c, None) for c in 'abc']) od = OrderedDict.fromkeys('abc', value=0) self.assertEqual(list(od.items()), [(c, 0) for c in 'abc'])
Example #7
Source File: test_collections.py From Fluid-Designer with GNU General Public License v3.0 | 5 votes |
def test_detect_deletion_during_iteration(self): OrderedDict = self.OrderedDict od = OrderedDict.fromkeys('abc') it = iter(od) key = next(it) del od[key] with self.assertRaises(Exception): # Note, the exact exception raised is not guaranteed # The only guarantee that the next() will not succeed next(it)
Example #8
Source File: test_collections.py From Fluid-Designer with GNU General Public License v3.0 | 5 votes |
def test_move_to_end(self): OrderedDict = self.OrderedDict od = OrderedDict.fromkeys('abcde') self.assertEqual(list(od), list('abcde')) od.move_to_end('c') self.assertEqual(list(od), list('abdec')) od.move_to_end('c', 0) self.assertEqual(list(od), list('cabde')) od.move_to_end('c', 0) self.assertEqual(list(od), list('cabde')) od.move_to_end('e') self.assertEqual(list(od), list('cabde')) od.move_to_end('b', last=False) self.assertEqual(list(od), list('bcade')) with self.assertRaises(KeyError): od.move_to_end('x') with self.assertRaises(KeyError): od.move_to_end('x', 0)
Example #9
Source File: test_collections.py From Fluid-Designer with GNU General Public License v3.0 | 5 votes |
def test_move_to_end_issue25406(self): OrderedDict = self.OrderedDict od = OrderedDict.fromkeys('abc') od.move_to_end('c', last=False) self.assertEqual(list(od), list('cab')) od.move_to_end('a', last=False) self.assertEqual(list(od), list('acb')) od = OrderedDict.fromkeys('abc') od.move_to_end('a') self.assertEqual(list(od), list('bca')) od.move_to_end('c') self.assertEqual(list(od), list('bac'))
Example #10
Source File: test_collections.py From Fluid-Designer with GNU General Public License v3.0 | 5 votes |
def test_key_change_during_iteration(self): OrderedDict = self.OrderedDict od = OrderedDict.fromkeys('abcde') self.assertEqual(list(od), list('abcde')) with self.assertRaises(RuntimeError): for i, k in enumerate(od): od.move_to_end(k) self.assertLess(i, 5) with self.assertRaises(RuntimeError): for k in od: od['f'] = None with self.assertRaises(RuntimeError): for k in od: del od['c'] self.assertEqual(list(od), list('bdeaf'))
Example #11
Source File: scheduler.py From builds with GNU General Public License v3.0 | 5 votes |
def _dfs(self, packages, visited): """ Perform a depth-first search to order packages by dependencies Args: packages ([Package]): all packages visited ([Package]): visited packages Returns: [Package]: ordered list of packages """ order = [] try: p = packages[0] except IndexError: pass else: if p not in visited: visited.append(p) # runtime dependencies do not need to be built before the package, # they can be built anytime. We randomly chose to prioritize building # installation dependencies before the package. if p.install_dependencies: order.extend(self._dfs(p.install_dependencies, visited)) if p.build_dependencies: order.extend(self._dfs(p.build_dependencies, visited)) order.append(p) order.extend(self._dfs(packages[1:], visited)) return list(OrderedDict.fromkeys(order))
Example #12
Source File: custom_sqlite.py From dffml with MIT License | 5 votes |
def update(self, record: Record): db = self.parent.db # Store feature data feature_cols = self.parent.FEATURE_COLS feature_data = OrderedDict.fromkeys(feature_cols) feature_data.update(record.features(feature_cols)) await db.execute( "INSERT OR REPLACE INTO features (key, " + ", ".join(feature_cols) + ") " "VALUES(?, " + ", ".join("?" * len(feature_cols)) + ")", [record.key] + list(feature_data.values()), ) # Store prediction try: prediction = record.prediction("target_name") prediction_cols = self.parent.PREDICTION_COLS prediction_data = OrderedDict.fromkeys(prediction_cols) prediction_data.update(prediction.dict()) await db.execute( "INSERT OR REPLACE INTO prediction (key, " + ", ".join(prediction_cols) + ") " "VALUES(?, " + ", ".join("?" * len(prediction_cols)) + ")", [record.key] + list(prediction_data.values()), ) except KeyError: pass
Example #13
Source File: lib.py From johnnydep with MIT License | 5 votes |
def gen_table(johnnydist, extra_cols=()): extra_cols = OrderedDict.fromkeys(extra_cols) # de-dupe and preserve ordering extra_cols.pop("name", None) # this is always included anyway, no need to ask for it johnnydist.log.debug("generating table") for pre, _fill, node in anytree.RenderTree(johnnydist): row = OrderedDict() name = str(node.req) if "specifier" in extra_cols: name = wimpy.strip_suffix(name, str(node.specifier)) row["name"] = pre + name for col in extra_cols: val = getattr(node, col, "") if isinstance(val, list): val = ", ".join(val) row[col] = val yield row
Example #14
Source File: test_collections.py From Fluid-Designer with GNU General Public License v3.0 | 5 votes |
def test_multiset_operations(self): # Verify that adding a zero counter will strip zeros and negatives c = Counter(a=10, b=-2, c=0) + Counter() self.assertEqual(dict(c), dict(a=10)) elements = 'abcd' for i in range(1000): # test random pairs of multisets p = Counter(dict((elem, randrange(-2,4)) for elem in elements)) p.update(e=1, f=-1, g=0) q = Counter(dict((elem, randrange(-2,4)) for elem in elements)) q.update(h=1, i=-1, j=0) for counterop, numberop in [ (Counter.__add__, lambda x, y: max(0, x+y)), (Counter.__sub__, lambda x, y: max(0, x-y)), (Counter.__or__, lambda x, y: max(0,x,y)), (Counter.__and__, lambda x, y: max(0, min(x,y))), ]: result = counterop(p, q) for x in elements: self.assertEqual(numberop(p[x], q[x]), result[x], (counterop, x, p, q)) # verify that results exclude non-positive counts self.assertTrue(x>0 for x in result.values()) elements = 'abcdef' for i in range(100): # verify that random multisets with no repeats are exactly like sets p = Counter(dict((elem, randrange(0, 2)) for elem in elements)) q = Counter(dict((elem, randrange(0, 2)) for elem in elements)) for counterop, setop in [ (Counter.__sub__, set.__sub__), (Counter.__or__, set.__or__), (Counter.__and__, set.__and__), ]: counter_result = counterop(p, q) set_result = setop(set(p.elements()), set(q.elements())) self.assertEqual(counter_result, dict.fromkeys(set_result, 1))
Example #15
Source File: duplicate_filter.py From catch with MIT License | 5 votes |
def _filter(self, input): """Return a subset of the input probes. """ # `return list(set(input))` would be a short way to produce # non-duplicate probes, but would not preserve the input # order. Instead, preserve the order with an OrderedDict. return list(OrderedDict.fromkeys(input))
Example #16
Source File: SmeegeScrape.py From SmeegeScrape with BSD 3-Clause "New" or "Revised" License | 5 votes |
def output(): try: if not args.outputFile: args.outputFile = 'smeegescrape_out.txt' outputFile = open(args.outputFile, 'w') wordListFinal = OrderedDict.fromkeys(wordList).keys() for word in wordListFinal: outputFile.write(word) outputFile.write('\n') outputFile.close() print '\n{0} unique words have been scraped.'.format(len(wordListFinal)) print 'Output file successfully written: {0}'.format(outputFile.name) except Exception as e: print 'Error creating output file: {0}'.format(outputFile.name) print e
Example #17
Source File: misc.py From pipenv with MIT License | 5 votes |
def dedup(iterable): # type: (Iterable) -> Iterable """Deduplicate an iterable object like iter(set(iterable)) but order- preserved.""" return iter(OrderedDict.fromkeys(iterable))
Example #18
Source File: utils.py From pipenv with MIT License | 5 votes |
def dedup(iterable): # type: (Iterable) -> Iterable """Deduplicate an iterable object like iter(set(iterable)) but order-reserved. """ return iter(OrderedDict.fromkeys(iterable))
Example #19
Source File: collector.py From pipenv with MIT License | 5 votes |
def _remove_duplicate_links(links): # type: (Iterable[Link]) -> List[Link] """ Return a list of links, with duplicates removed and ordering preserved. """ # We preserve the ordering when removing duplicates because we can. return list(OrderedDict.fromkeys(links))
Example #20
Source File: utils.py From pipenv with MIT License | 5 votes |
def dedup(iterable): """Deduplicate an iterable object like iter(set(iterable)) but order-preserved. """ return iter(OrderedDict.fromkeys(iterable))
Example #21
Source File: logManager.py From crazyflieROS with GNU General Public License v2.0 | 5 votes |
def getValidHZ(self, hz): # zip(list(OrderedDict.fromkeys([round(100/floor(100/x),2) for x in range(1,100)])),list(OrderedDict.fromkeys([1000/round(100/floor(100/x),2) for x in range(1,100)]))) i = bisect.bisect_left(self.validHZ, hz) vHZ = min(self.validHZ[max(0, i-1): i+2], key=lambda t: abs(hz - t)) if hz!=vHZ: rospy.loginfo("Could not set HZ to specific value [%d], rounded to valid HZ [%.4f]", hz, vHZ) return vHZ
Example #22
Source File: logManager.py From crazyflieROS with GNU General Public License v2.0 | 5 votes |
def __init__(self, parent, name, children, hz=50): super(LogGroup, self).__init__(parent) self.name = name self.setFlags(self.flags() | Qt.ItemIsEditable | Qt.ItemIsUserCheckable) # Keep track of if all/none of the children are active self.cAll = True self.cNone = True self.validHZ = list(OrderedDict.fromkeys([round(100/floor(100/x),2) for x in range(1,100)])) self.hzTarget = hz # Monitor the incoming frequency self.fm = None self.fmOn = True # log config self.lg = None # Show text QtGui.QTreeWidgetItem.setData(self, 0, Qt.DisplayRole, QVariant(name)) QtGui.QTreeWidgetItem.setData(self, 0, Qt.CheckStateRole, Qt.Unchecked) QtGui.QTreeWidgetItem.setData(self, 1, Qt.DisplayRole, "Off") QtGui.QTreeWidgetItem.setData(self, 3, Qt.DisplayRole, QVariant(0)) #QtGui.QTreeWidgetItem.setData(self, 4, Qt.CheckStateRole, Qt.Unchecked) self.readSettings() # Initialise Children for c in sorted(children.keys()): self.addChild(LogItem(self, children[c])) self.c = 0 # Now everything is initialised except the logging # Start logging if active if self.checkState(0) == Qt.Checked: self.requestLog()
Example #23
Source File: model_manager.py From opcua-modeler with GNU General Public License v3.0 | 5 votes |
def save_xml(self, path=None): self._save_structs() path = self._get_path(path) path += ".xml" logger.info("Saving nodes to %s", path) logger.info("Exporting %s nodes: %s", len(self.new_nodes), self.new_nodes) logger.info("and namespaces: %s ", self.server_mgr.get_namespace_array()[1:]) uris = self.server_mgr.get_namespace_array()[1:] self.new_nodes = list(OrderedDict.fromkeys(self.new_nodes)) # remove any potential duplicate self.server_mgr.export_xml(self.new_nodes, uris, path) self.modified = False logger.info("%s saved", path) self._show_structs() #_save_structs has delete our design nodes for structure, we need to recreate them
Example #24
Source File: collector.py From pex with Apache License 2.0 | 5 votes |
def _remove_duplicate_links(links): # type: (Iterable[Link]) -> List[Link] """ Return a list of links, with duplicates removed and ordering preserved. """ # We preserve the ordering when removing duplicates because we can. return list(OrderedDict.fromkeys(links))
Example #25
Source File: utils.py From pythonfinder with MIT License | 5 votes |
def dedup(iterable): # type: (Iterable) -> Iterable """Deduplicate an iterable object like iter(set(iterable)) but order-reserved. """ return iter(OrderedDict.fromkeys(iterable))
Example #26
Source File: category.py From Mastering-Elasticsearch-7.0 with MIT License | 5 votes |
def update(self, data): """Maps new values to integer identifiers. Parameters ---------- data : iterable sequence of string values Raises ------ TypeError If the value in data is not a string, unicode, bytes type """ data = np.atleast_1d(np.array(data, dtype=object)) # check if convertible to number: convertible = True for val in OrderedDict.fromkeys(data): # OrderedDict just iterates over unique values in data. if not isinstance(val, (str, bytes)): raise TypeError("{val!r} is not a string".format(val=val)) if convertible: # this will only be called so long as convertible is True. convertible = self._str_is_convertible(val) if val not in self._mapping: self._mapping[val] = next(self._counter) if convertible: _log.info('Using categorical units to plot a list of strings ' 'that are all parsable as floats or dates. If these ' 'strings should be plotted as numbers, cast to the ' 'appropriate data type before plotting.') # Register the converter with Matplotlib's unit framework
Example #27
Source File: test_collections.py From oss-ftp with MIT License | 5 votes |
def test_views(self): s = 'the quick brown fox jumped over a lazy dog yesterday before dawn'.split() od = OrderedDict.fromkeys(s) self.assertEqual(list(od.viewkeys()), s) self.assertEqual(list(od.viewvalues()), [None for k in s]) self.assertEqual(list(od.viewitems()), [(k, None) for k in s])
Example #28
Source File: test_collections.py From oss-ftp with MIT License | 5 votes |
def test_repr_recursive(self): # See issue #9826 od = OrderedDict.fromkeys('abc') od['x'] = od self.assertEqual(repr(od), "OrderedDict([('a', None), ('b', None), ('c', None), ('x', ...)])")
Example #29
Source File: test_collections.py From oss-ftp with MIT License | 5 votes |
def test_multiset_operations(self): # Verify that adding a zero counter will strip zeros and negatives c = Counter(a=10, b=-2, c=0) + Counter() self.assertEqual(dict(c), dict(a=10)) elements = 'abcd' for i in range(1000): # test random pairs of multisets p = Counter(dict((elem, randrange(-2,4)) for elem in elements)) p.update(e=1, f=-1, g=0) q = Counter(dict((elem, randrange(-2,4)) for elem in elements)) q.update(h=1, i=-1, j=0) for counterop, numberop in [ (Counter.__add__, lambda x, y: max(0, x+y)), (Counter.__sub__, lambda x, y: max(0, x-y)), (Counter.__or__, lambda x, y: max(0,x,y)), (Counter.__and__, lambda x, y: max(0, min(x,y))), ]: result = counterop(p, q) for x in elements: self.assertEqual(numberop(p[x], q[x]), result[x], (counterop, x, p, q)) # verify that results exclude non-positive counts self.assertTrue(x>0 for x in result.values()) elements = 'abcdef' for i in range(100): # verify that random multisets with no repeats are exactly like sets p = Counter(dict((elem, randrange(0, 2)) for elem in elements)) q = Counter(dict((elem, randrange(0, 2)) for elem in elements)) for counterop, setop in [ (Counter.__sub__, set.__sub__), (Counter.__or__, set.__or__), (Counter.__and__, set.__and__), ]: counter_result = counterop(p, q) set_result = setop(set(p.elements()), set(q.elements())) self.assertEqual(counter_result, dict.fromkeys(set_result, 1))
Example #30
Source File: test_collections.py From oss-ftp with MIT License | 5 votes |
def validate_abstract_methods(self, abc, *names): methodstubs = dict.fromkeys(names, lambda s, *args: 0) # everything should work will all required methods are present C = type('C', (abc,), methodstubs) C() # instantiation should fail if a required method is missing for name in names: stubs = methodstubs.copy() del stubs[name] C = type('C', (abc,), stubs) self.assertRaises(TypeError, C, name)