LSSTApplications  19.0.0-14-gb0260a2+72efe9b372,20.0.0+7927753e06,20.0.0+8829bf0056,20.0.0+995114c5d2,20.0.0+b6f4b2abd1,20.0.0+bddc4f4cbe,20.0.0-1-g253301a+8829bf0056,20.0.0-1-g2b7511a+0d71a2d77f,20.0.0-1-g5b95a8c+7461dd0434,20.0.0-12-g321c96ea+23efe4bbff,20.0.0-16-gfab17e72e+fdf35455f6,20.0.0-2-g0070d88+ba3ffc8f0b,20.0.0-2-g4dae9ad+ee58a624b3,20.0.0-2-g61b8584+5d3db074ba,20.0.0-2-gb780d76+d529cf1a41,20.0.0-2-ged6426c+226a441f5f,20.0.0-2-gf072044+8829bf0056,20.0.0-2-gf1f7952+ee58a624b3,20.0.0-20-geae50cf+e37fec0aee,20.0.0-25-g3dcad98+544a109665,20.0.0-25-g5eafb0f+ee58a624b3,20.0.0-27-g64178ef+f1f297b00a,20.0.0-3-g4cc78c6+e0676b0dc8,20.0.0-3-g8f21e14+4fd2c12c9a,20.0.0-3-gbd60e8c+187b78b4b8,20.0.0-3-gbecbe05+48431fa087,20.0.0-38-ge4adf513+a12e1f8e37,20.0.0-4-g97dc21a+544a109665,20.0.0-4-gb4befbc+087873070b,20.0.0-4-gf910f65+5d3db074ba,20.0.0-5-gdfe0fee+199202a608,20.0.0-5-gfbfe500+d529cf1a41,20.0.0-6-g64f541c+d529cf1a41,20.0.0-6-g9a5b7a1+a1cd37312e,20.0.0-68-ga3f3dda+5fca18c6a4,20.0.0-9-g4aef684+e18322736b,w.2020.45
LSSTDataManagementBasePackage
Functions
lsst.daf.persistence.utils Namespace Reference

Functions

def listify (x)
 
def iterify (x)
 
def sequencify (x)
 
def setify (x)
 
def doImport (pythonType)
 

Function Documentation

◆ doImport()

def lsst.daf.persistence.utils.doImport (   pythonType)
Import a python object given an importable string

Definition at line 104 of file utils.py.

104 def doImport(pythonType):
105  """Import a python object given an importable string"""
106  try:
107  if not isinstance(pythonType, str):
108  raise TypeError("Unhandled type of pythonType, val:%s" % pythonType)
109  # import this pythonType dynamically
110  pythonTypeTokenList = pythonType.split('.')
111  importClassString = pythonTypeTokenList.pop()
112  importClassString = importClassString.strip()
113  importPackage = ".".join(pythonTypeTokenList)
114  importType = __import__(importPackage, globals(), locals(), [importClassString], 0)
115  pythonType = getattr(importType, importClassString)
116  return pythonType
117  except ImportError:
118  pass
119  # maybe python type is a member function, in the form: path.to.object.Class.funcname
120  pythonTypeTokenList = pythonType.split('.')
121  importClassString = '.'.join(pythonTypeTokenList[0:-1])
122  importedClass = doImport(importClassString)
123  pythonType = getattr(importedClass, pythonTypeTokenList[-1])
124  return pythonType

◆ iterify()

def lsst.daf.persistence.utils.iterify (   x)
Takes any object. Returns it if it is iterable. If it
is not iterable it puts the object in a list and returns
the list. None will return an empty list. If a new list
is always required use listify(). Strings will be placed
in a list with a single element.

Definition at line 49 of file utils.py.

49 def iterify(x):
50  """Takes any object. Returns it if it is iterable. If it
51  is not iterable it puts the object in a list and returns
52  the list. None will return an empty list. If a new list
53  is always required use listify(). Strings will be placed
54  in a list with a single element.
55  """
56  if x is None:
57  x = []
58  elif isinstance(x, str):
59  x = [x]
60  elif hasattr(x, '__iter__'):
61  pass
62  else:
63  x = [x]
64  return x
65 
66 

◆ listify()

def lsst.daf.persistence.utils.listify (   x)
Takes any object and puts that whole object in a list:
- strings will be made into a single element in the list
- tuples will be converted to list
- lists will remain as lists
- None will be made into an empty list

Definition at line 29 of file utils.py.

29 def listify(x):
30  """Takes any object and puts that whole object in a list:
31  - strings will be made into a single element in the list
32  - tuples will be converted to list
33  - lists will remain as lists
34  - None will be made into an empty list
35  """
36  if x is None:
37  x = []
38  elif isinstance(x, str):
39  x = [x]
40  elif isinstance(x, dict):
41  x = [x]
42  elif hasattr(x, '__iter__'):
43  x = list(x)
44  else:
45  x = [x]
46  return x
47 
48 

◆ sequencify()

def lsst.daf.persistence.utils.sequencify (   x)
Takes an object, if it is a sequence return it,
else put it in a tuple. Strings are not sequences.
If x is a dict, returns a sorted tuple of keys.

Definition at line 67 of file utils.py.

67 def sequencify(x):
68  """Takes an object, if it is a sequence return it,
69  else put it in a tuple. Strings are not sequences.
70  If x is a dict, returns a sorted tuple of keys."""
71  if isinstance(x, (Sequence, Set)) and not isinstance(x, str):
72  pass
73  elif isinstance(x, Mapping):
74  x = tuple(sorted(x.keys()))
75  else:
76  x = (x, )
77  return x
78 
79 

◆ setify()

def lsst.daf.persistence.utils.setify (   x)
Take an object x and return it in a set.

If x is a container, will create a set from the contents of the container.
If x is an object, will create a set with a single item in it.
If x is a string, will treat the string as a single object (i.e. not as a list of chars)

Definition at line 80 of file utils.py.

80 def setify(x):
81  """Take an object x and return it in a set.
82 
83  If x is a container, will create a set from the contents of the container.
84  If x is an object, will create a set with a single item in it.
85  If x is a string, will treat the string as a single object (i.e. not as a list of chars)"""
86  if x is None:
87  x = set()
88 
89  # Here we have to explicity for strings because the set initializer will use each character in a string as
90  # a separate element. We cannot use the braces initialization because x might be a list, and we do not
91  # want the list to be an item; we want each item in the list to be represented by an item in the set.
92  # Then, we have to fall back to braces init because if the item is NOT a list then the set initializer
93  # won't take it.
94  if isinstance(x, str):
95  x = set([x])
96  else:
97  try:
98  x = set(x)
99  except TypeError:
100  x = set([x])
101  return x
102 
103 
lsst::daf::persistence.utils.doImport
def doImport(pythonType)
Definition: utils.py:104
lsst::daf::persistence.utils.sequencify
def sequencify(x)
Definition: utils.py:67
lsst::daf::persistence.utils.listify
def listify(x)
Definition: utils.py:29
lsst::daf::persistence.utils.setify
def setify(x)
Definition: utils.py:80
list
daf::base::PropertyList * list
Definition: fits.cc:913
lsst::daf::persistence.utils.iterify
def iterify(x)
Definition: utils.py:49
set
daf::base::PropertySet * set
Definition: fits.cc:912