Source code for paraview.util

# These functions were present in a util.py module.
# Keeping them around for backwards compatibility
[docs]def SetOutputWholeExtent(algorithm, extent): """ Convenience method to help set the WHOLE_EXTENT() in RequestInformation. Commonly used by programmable filters. The arguments are the algorithm and a tuple/list with 6 elements (xmin, xmax, ymin, ymax, zmin, zmax). Example use:: import paraview.util # The output will be of dimensions 10, 1, 1 paraview.util.SetOutputWholeExtent(algorithm, (0, 9, 0, 0, 0, 0) """ if len(extent) != 6: raise "Expected a sequence of length 6" from vtkmodules.vtkCommonExecutionModel import vtkStreamingDemandDrivenPipeline algorithm.GetExecutive().GetOutputInformation(0).Set(vtkStreamingDemandDrivenPipeline.WHOLE_EXTENT(), extent[0], extent[1], extent[2], extent[3], extent[4], extent[5])
[docs]def IntegrateCell(dataset, cellId): """ This functions uses vtkCellIntegrator's Integrate method that calculates the length/area/volume of a 1D/2D/3D cell. The calculation is exact for lines, polylines, triangles, triangle strips, pixels, voxels, convex polygons, quads and tetrahedra. All other 3D cells are triangulated during volume calculation. In such cases, the result may not be exact. """ from paraview.modules.vtkPVVTKExtensionsFiltersGeneral import vtkCellIntegrator return vtkCellIntegrator.Integrate(dataset, cellId)
[docs]def ReplaceDollarVariablesWithEnvironment(text): """Replaces all substrings of the type `${FOO}` with `FOO` obtained from the `os.environ`. If the key is not defined in the environment, this raises a `KeyError`. """ import os, re r = re.compile(r"\$ENV\{([^}]+)\}") def repl(m): if m.group(1) in os.environ: return os.environ[m.group(1)] raise KeyError("'%s' is not defined in the process environment" % m.group(1)) return re.sub(r, repl, text)
[docs]def Glob(path, rootDir=None): """Given a path, this function performs globbing on the file names inside the input directory. rootDir is an optional parameter that can set a relative root directory from which path is defined. This function returns the list of files matching the globbing pattern (the wildcard * is an example of pattern that can be used) of the input path. Note that for this function to work, the globbing pattern needs to only belong to the file name at the end of path. fnmatch package is used as the backend for processing the input pattern. """ import paraview import paraview.simple import paraview.servermanager as sm import fnmatch import os.path head_tail = os.path.split(path) dirPath = head_tail[0] fileName = head_tail[1] fileInfoHelperProxy = sm.ProxyManager().NewProxy("misc", "FileInformationHelper") fileInfoHelperProxy.GetProperty("DirectoryListing").SetElement(0, True) fileInfoHelperProxy.GetProperty("Path").SetElement(0, dirPath) fileInfoHelperProxy.GetProperty("GroupFileSequences").SetElement(0, False) if rootDir != None: fileInfoHelperProxy.GetProperty("WorkingDirectory").SetElement(0, rootDir) fileInfoHelperProxy.UpdateVTKObjects() localFileInfo = sm.vtkPVFileInformation() fileInfoHelperProxy.GatherInformation(localFileInfo) numFiles = localFileInfo.GetContents().GetNumberOfItems() foundFiles = [] for i in range(numFiles): name = localFileInfo.GetContents().GetItemAsObject(i).GetName() if fnmatch.fnmatch(name, fileName): foundFiles.append(dirPath + '/' + name) foundFiles.sort() return foundFiles