Source code for openquake.engine.export.core

# Copyright (c) 2010-2014, GEM Foundation.
#
# OpenQuake is free software: you can redistribute it and/or modify it
# under the terms of the GNU Affero General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# OpenQuake is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with OpenQuake.  If not, see <http://www.gnu.org/licenses/>.

"""Functions for getting information about completed jobs and
calculation outputs, as well as exporting outputs from the database to various
file formats."""


import os
from openquake.engine.db import models
from openquake.engine.logs import LOG
from openquake.baselib.general import CallableDict

export_output = CallableDict()


[docs]def export(output_id, target, export_type='xml,geojson,csv'): """ Export the given calculation `output_id` from the database to the specified `target` directory in the specified `export_type`. """ output = models.Output.objects.get(id=output_id) if isinstance(target, basestring): # create target directory makedirs(target) for exptype in export_type.split(','): key = (output.output_type, exptype) if key in export_output: return export_output(key, output, target) LOG.warn( 'No "%(fmt)s" exporter is available for "%(output_type)s"' ' outputs' % dict(fmt=export_type, output_type=output.output_type))
#: Used to separate node labels in a logic tree path LT_PATH_JOIN_TOKEN = '_'
[docs]def makedirs(path): """ Make all of the directories in the ``path`` using `os.makedirs`. """ if os.path.exists(path): if not os.path.isdir(path): # If it's not a directory, we can't do anything. # This is a problem raise RuntimeError('%s already exists and is not a directory.' % path) else: os.makedirs(path)
[docs]def get_outputs(job_id, output_type=None): """Get all :class:`openquake.engine.db.models.Output` objects associated with the specified job and output_type. :param int job_id: ID of a :class:`openquake.engine.db.models.OqJob`. :param str output_type: the output type; if None, return all outputs :returns: :class:`django.db.models.query.QuerySet` of :class:`openquake.engine.db.models.Output` objects. """ queryset = models.Output.objects.filter(oq_job=job_id) if output_type: return queryset.filter(output_type=output_type) return queryset