source: flex_extract.git/documentation/Sphinx/build/html/_modules/tools.html @ 708c667

ctbtodev
Last change on this file since 708c667 was 708c667, checked in by Anne Philipp <anne.philipp@…>, 6 years ago

generated first sphinx instance and adapted code doctsrings for automated api generation for disaggregation module as a first test

  • Property mode set to 100644
File size: 62.6 KB
Line 
1
2
3<!DOCTYPE html>
4<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
5<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
6<head>
7  <meta charset="utf-8">
8 
9  <meta name="viewport" content="width=device-width, initial-scale=1.0">
10 
11  <title>tools &mdash; flex_extract 7.1 alpha documentation</title>
12 
13
14 
15 
16 
17 
18
19 
20
21 
22 
23   
24
25 
26
27  <link rel="stylesheet" href="../_static/css/theme.css" type="text/css" />
28  <link rel="stylesheet" href="../_static/pygments.css" type="text/css" />
29    <link rel="index" title="Index" href="../genindex.html" />
30    <link rel="search" title="Search" href="../search.html" /> 
31
32 
33  <script src="../_static/js/modernizr.min.js"></script>
34
35</head>
36
37<body class="wy-body-for-nav">
38
39   
40  <div class="wy-grid-for-nav">
41
42   
43    <nav data-toggle="wy-nav-shift" class="wy-nav-side">
44      <div class="wy-side-scroll">
45        <div class="wy-side-nav-search">
46         
47
48         
49            <a href="../index.html" class="icon icon-home"> flex_extract
50         
51
52         
53          </a>
54
55         
56           
57           
58              <div class="version">
59                7.1
60              </div>
61           
62         
63
64         
65<div role="search">
66  <form id="rtd-search-form" class="wy-form" action="../search.html" method="get">
67    <input type="text" name="q" placeholder="Search docs" />
68    <input type="hidden" name="check_keywords" value="yes" />
69    <input type="hidden" name="area" value="default" />
70  </form>
71</div>
72
73         
74        </div>
75
76        <div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
77         
78           
79           
80             
81           
82           
83              <p class="caption"><span class="caption-text">Table of Contents:</span></p>
84<ul>
85<li class="toctree-l1"><a class="reference internal" href="../downloads.html">Downloads</a></li>
86<li class="toctree-l1"><a class="reference internal" href="../installation.html">Installation</a></li>
87<li class="toctree-l1"><a class="reference internal" href="../program_structure.html">Program Structure</a></li>
88<li class="toctree-l1"><a class="reference internal" href="../user_guide.html">User Guide</a></li>
89<li class="toctree-l1"><a class="reference internal" href="../api.html">Auto Generated Documentation</a></li>
90<li class="toctree-l1"><a class="reference internal" href="../support.html">Support</a></li>
91</ul>
92
93           
94         
95        </div>
96      </div>
97    </nav>
98
99    <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
100
101     
102      <nav class="wy-nav-top" aria-label="top navigation">
103       
104          <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
105          <a href="../index.html">flex_extract</a>
106       
107      </nav>
108
109
110      <div class="wy-nav-content">
111       
112        <div class="rst-content">
113       
114         
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130<div role="navigation" aria-label="breadcrumbs navigation">
131
132  <ul class="wy-breadcrumbs">
133   
134      <li><a href="../index.html">Docs</a> &raquo;</li>
135       
136          <li><a href="index.html">Module code</a> &raquo;</li>
137       
138      <li>tools</li>
139   
140   
141      <li class="wy-breadcrumbs-aside">
142       
143      </li>
144   
145  </ul>
146
147 
148  <hr/>
149</div>
150          <div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
151           <div itemprop="articleBody">
152           
153  <h1>Source code for tools</h1><div class="highlight"><pre>
154<span></span><span class="ch">#!/usr/bin/env python</span>
155<span class="c1"># -*- coding: utf-8 -*-</span>
156<span class="c1">#*******************************************************************************</span>
157<span class="c1"># @Author: Anne Philipp (University of Vienna)</span>
158<span class="c1">#</span>
159<span class="c1"># @Date: May 2018</span>
160<span class="c1">#</span>
161<span class="c1"># @Change History:</span>
162<span class="c1">#    October 2014 - Anne Fouilloux (University of Oslo)</span>
163<span class="c1">#        - created functions silent_remove and product (taken from ECMWF)</span>
164<span class="c1">#</span>
165<span class="c1">#    November 2015 - Leopold Haimberger (University of Vienna)</span>
166<span class="c1">#        - created functions: interpret_args_and_control, clean_up</span>
167<span class="c1">#          my_error, normal_exit, init128, to_param_id</span>
168<span class="c1">#</span>
169<span class="c1">#    April 2018 - Anne Philipp (University of Vienna):</span>
170<span class="c1">#        - applied PEP8 style guide</span>
171<span class="c1">#        - added documentation</span>
172<span class="c1">#        - moved all functions from file Flexparttools to this file tools</span>
173<span class="c1">#        - added function get_list_as_string</span>
174<span class="c1">#        - seperated args and control interpretation</span>
175<span class="c1">#</span>
176<span class="c1"># @License:</span>
177<span class="c1">#    (C) Copyright 2014-2018.</span>
178<span class="c1">#</span>
179<span class="c1">#    This software is licensed under the terms of the Apache Licence Version 2.0</span>
180<span class="c1">#    which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.</span>
181<span class="c1">#</span>
182<span class="c1"># @Modul Description:</span>
183<span class="c1">#    This module contains a couple of helpful functions which are</span>
184<span class="c1">#    used in different places in flex_extract.</span>
185<span class="c1">#</span>
186<span class="c1"># @Module Content:</span>
187<span class="c1">#    - get_cmdline_arguments</span>
188<span class="c1">#    - clean_up</span>
189<span class="c1">#    - my_error</span>
190<span class="c1">#    - normal_exit</span>
191<span class="c1">#    - product</span>
192<span class="c1">#    - silent_remove</span>
193<span class="c1">#    - init128</span>
194<span class="c1">#    - to_param_id</span>
195<span class="c1">#    - get_list_as_string</span>
196<span class="c1">#    - make_dir</span>
197<span class="c1">#</span>
198<span class="c1">#*******************************************************************************</span>
199
200<span class="c1"># ------------------------------------------------------------------------------</span>
201<span class="c1"># MODULES</span>
202<span class="c1"># ------------------------------------------------------------------------------</span>
203<span class="kn">import</span> <span class="nn">os</span>
204<span class="kn">import</span> <span class="nn">errno</span>
205<span class="kn">import</span> <span class="nn">sys</span>
206<span class="kn">import</span> <span class="nn">glob</span>
207<span class="kn">import</span> <span class="nn">subprocess</span>
208<span class="kn">import</span> <span class="nn">traceback</span>
209<span class="kn">from</span> <span class="nn">argparse</span> <span class="k">import</span> <span class="n">ArgumentParser</span><span class="p">,</span> <span class="n">ArgumentDefaultsHelpFormatter</span>
210
211<span class="c1"># ------------------------------------------------------------------------------</span>
212<span class="c1"># FUNCTIONS</span>
213<span class="c1"># ------------------------------------------------------------------------------</span>
214
215<div class="viewcode-block" id="none_or_str"><a class="viewcode-back" href="../code.html#tools.none_or_str">[docs]</a><span class="k">def</span> <span class="nf">none_or_str</span><span class="p">(</span><span class="n">value</span><span class="p">):</span>
216    <span class="sd">&#39;&#39;&#39;</span>
217<span class="sd">    @Description:</span>
218<span class="sd">        Converts the input string into pythons None-type if the string</span>
219<span class="sd">        contains &quot;None&quot;.</span>
220
221<span class="sd">    @Input:</span>
222<span class="sd">        value: string</span>
223<span class="sd">            String to be checked for the &quot;None&quot; word.</span>
224
225<span class="sd">    @Return:</span>
226<span class="sd">        None or value:</span>
227<span class="sd">            Return depends on the content of the input value. If it was &quot;None&quot;,</span>
228<span class="sd">            then the python type None is returned. Otherwise the string itself.</span>
229<span class="sd">    &#39;&#39;&#39;</span>
230    <span class="k">if</span> <span class="n">value</span> <span class="o">==</span> <span class="s1">&#39;None&#39;</span><span class="p">:</span>
231        <span class="k">return</span> <span class="kc">None</span>
232    <span class="k">return</span> <span class="n">value</span></div>
233
234<div class="viewcode-block" id="none_or_int"><a class="viewcode-back" href="../code.html#tools.none_or_int">[docs]</a><span class="k">def</span> <span class="nf">none_or_int</span><span class="p">(</span><span class="n">value</span><span class="p">):</span>
235    <span class="sd">&#39;&#39;&#39;</span>
236<span class="sd">    @Description:</span>
237<span class="sd">        Converts the input string into pythons None-type if the string</span>
238<span class="sd">        contains &quot;None&quot;. Otherwise it is converted to an integer value.</span>
239
240<span class="sd">    @Input:</span>
241<span class="sd">        value: string</span>
242<span class="sd">            String to be checked for the &quot;None&quot; word.</span>
243
244<span class="sd">    @Return:</span>
245<span class="sd">        None or int(value):</span>
246<span class="sd">            Return depends on the content of the input value. If it was &quot;None&quot;,</span>
247<span class="sd">            then the python type None is returned. Otherwise the string is</span>
248<span class="sd">            converted into an integer value.</span>
249<span class="sd">    &#39;&#39;&#39;</span>
250    <span class="k">if</span> <span class="n">value</span> <span class="o">==</span> <span class="s1">&#39;None&#39;</span><span class="p">:</span>
251        <span class="k">return</span> <span class="kc">None</span>
252    <span class="k">return</span> <span class="nb">int</span><span class="p">(</span><span class="n">value</span><span class="p">)</span></div>
253
254<div class="viewcode-block" id="get_cmdline_arguments"><a class="viewcode-back" href="../code.html#tools.get_cmdline_arguments">[docs]</a><span class="k">def</span> <span class="nf">get_cmdline_arguments</span><span class="p">():</span>
255    <span class="sd">&#39;&#39;&#39;</span>
256<span class="sd">    @Description:</span>
257<span class="sd">        Decomposes the command line arguments and assigns them to variables.</span>
258<span class="sd">        Apply default values for non mentioned arguments.</span>
259
260<span class="sd">    @Input:</span>
261<span class="sd">        &lt;nothing&gt;</span>
262
263<span class="sd">    @Return:</span>
264<span class="sd">        args: instance of ArgumentParser</span>
265<span class="sd">            Contains the commandline arguments from script/program call.</span>
266<span class="sd">    &#39;&#39;&#39;</span>
267
268    <span class="n">parser</span> <span class="o">=</span> <span class="n">ArgumentParser</span><span class="p">(</span><span class="n">description</span><span class="o">=</span><span class="s1">&#39;Retrieve FLEXPART input from </span><span class="se">\</span>
269<span class="s1">                                ECMWF MARS archive&#39;</span><span class="p">,</span>
270                            <span class="n">formatter_class</span><span class="o">=</span><span class="n">ArgumentDefaultsHelpFormatter</span><span class="p">)</span>
271
272    <span class="c1"># the most important arguments</span>
273    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--start_date&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;start_date&quot;</span><span class="p">,</span>
274                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
275                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;start date YYYYMMDD&quot;</span><span class="p">)</span>
276    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--end_date&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;end_date&quot;</span><span class="p">,</span>
277                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
278                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;end_date YYYYMMDD&quot;</span><span class="p">)</span>
279    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--date_chunk&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;date_chunk&quot;</span><span class="p">,</span>
280                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_int</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
281                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;# of days to be retrieved at once&quot;</span><span class="p">)</span>
282    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--controlfile&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;controlfile&quot;</span><span class="p">,</span>
283                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="s1">&#39;CONTROL.temp&#39;</span><span class="p">,</span>
284                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;file with CONTROL parameters&quot;</span><span class="p">)</span>
285
286    <span class="c1"># parameter for extra output information</span>
287    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--debug&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;debug&quot;</span><span class="p">,</span>
288                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_int</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
289                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;debug mode - leave temporary files intact&quot;</span><span class="p">)</span>
290    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--request&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;request&quot;</span><span class="p">,</span>
291                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_int</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
292                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;list all mars request in file mars_requests.dat </span><span class="se">\</span>
293<span class="s2">                        and skip submission to mars&quot;</span><span class="p">)</span>
294    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--public&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;public&quot;</span><span class="p">,</span>
295                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_int</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
296                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;public mode - retrieves the public datasets&quot;</span><span class="p">)</span>
297
298    <span class="c1"># some arguments that override the default in the CONTROL file</span>
299    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--basetime&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;basetime&quot;</span><span class="p">,</span>
300                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_int</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
301                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;base such as 00 or 12 (for half day retrievals)&quot;</span><span class="p">)</span>
302    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--step&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;step&quot;</span><span class="p">,</span>
303                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
304                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;steps such as 00/to/48&quot;</span><span class="p">)</span>
305    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--levelist&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;levelist&quot;</span><span class="p">,</span>
306                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
307                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;Vertical levels to be retrieved, e.g. 30/to/60&quot;</span><span class="p">)</span>
308    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--area&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;area&quot;</span><span class="p">,</span>
309                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
310                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;area defined as north/west/south/east&quot;</span><span class="p">)</span>
311
312    <span class="c1"># set the working directories</span>
313    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--inputdir&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;inputdir&quot;</span><span class="p">,</span>
314                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
315                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;root directory for storing intermediate files&quot;</span><span class="p">)</span>
316    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--outputdir&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;outputdir&quot;</span><span class="p">,</span>
317                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
318                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;root directory for storing output files&quot;</span><span class="p">)</span>
319    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--flexpart_root_scripts&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;flexpart_root_scripts&quot;</span><span class="p">,</span>
320                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
321                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;FLEXPART root directory (to find grib2flexpart </span><span class="se">\</span>
322<span class="s2">                        and COMMAND file)</span><span class="se">\n</span><span class="s2"> Normally flex_extract resides in </span><span class="se">\</span>
323<span class="s2">                        the scripts directory of the FLEXPART distribution&quot;</span><span class="p">)</span>
324
325    <span class="c1"># this is only used by prepare_flexpart.py to rerun a postprocessing step</span>
326    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--ppid&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;ppid&quot;</span><span class="p">,</span>
327                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_int</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
328                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;specify parent process id for </span><span class="se">\</span>
329<span class="s2">                        rerun of prepare_flexpart&quot;</span><span class="p">)</span>
330
331    <span class="c1"># arguments for job submission to ECMWF, only needed by submit.py</span>
332    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--job_template&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s1">&#39;job_template&#39;</span><span class="p">,</span>
333                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="s2">&quot;job.temp&quot;</span><span class="p">,</span>
334                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;job template file for submission to ECMWF&quot;</span><span class="p">)</span>
335    <span class="n">parser</span><span class="o">.</span><span class="n">add_argument</span><span class="p">(</span><span class="s2">&quot;--queue&quot;</span><span class="p">,</span> <span class="n">dest</span><span class="o">=</span><span class="s2">&quot;queue&quot;</span><span class="p">,</span>
336                        <span class="nb">type</span><span class="o">=</span><span class="n">none_or_str</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span>
337                        <span class="n">help</span><span class="o">=</span><span class="s2">&quot;queue for submission to ECMWF </span><span class="se">\</span>
338<span class="s2">                        (e.g. ecgate or cca )&quot;</span><span class="p">)</span>
339
340    <span class="n">args</span> <span class="o">=</span> <span class="n">parser</span><span class="o">.</span><span class="n">parse_args</span><span class="p">()</span>
341
342    <span class="k">return</span> <span class="n">args</span></div>
343
344<div class="viewcode-block" id="read_ecenv"><a class="viewcode-back" href="../code.html#tools.read_ecenv">[docs]</a><span class="k">def</span> <span class="nf">read_ecenv</span><span class="p">(</span><span class="n">filename</span><span class="p">):</span>
345    <span class="sd">&#39;&#39;&#39;</span>
346<span class="sd">    @Description:</span>
347<span class="sd">        Reads the file into a dictionary where the key values are the parameter</span>
348<span class="sd">        names.</span>
349
350<span class="sd">    @Input:</span>
351<span class="sd">        filename: string</span>
352<span class="sd">            Path to file where the ECMWV environment parameters are stored.</span>
353
354<span class="sd">    @Return:</span>
355<span class="sd">        envs: dict</span>
356<span class="sd">            Contains the environment parameter ecuid, ecgid, gateway</span>
357<span class="sd">            and destination for ECMWF server environments.</span>
358<span class="sd">    &#39;&#39;&#39;</span>
359    <span class="n">envs</span><span class="o">=</span> <span class="p">{}</span>
360
361    <span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="n">filename</span><span class="p">,</span> <span class="s1">&#39;r&#39;</span><span class="p">)</span> <span class="k">as</span> <span class="n">f</span><span class="p">:</span>
362        <span class="k">for</span> <span class="n">line</span> <span class="ow">in</span> <span class="n">f</span><span class="p">:</span>
363            <span class="n">data</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span><span class="o">.</span><span class="n">split</span><span class="p">()</span>
364            <span class="n">envs</span><span class="p">[</span><span class="nb">str</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="mi">0</span><span class="p">])]</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span>
365
366    <span class="k">return</span> <span class="n">envs</span></div>
367
368<div class="viewcode-block" id="clean_up"><a class="viewcode-back" href="../code.html#tools.clean_up">[docs]</a><span class="k">def</span> <span class="nf">clean_up</span><span class="p">(</span><span class="n">c</span><span class="p">):</span>
369    <span class="sd">&#39;&#39;&#39;</span>
370<span class="sd">    @Description:</span>
371<span class="sd">        Remove all files from intermediate directory</span>
372<span class="sd">        (inputdir from CONTROL file).</span>
373
374<span class="sd">    @Input:</span>
375<span class="sd">        c: instance of class ControlFile</span>
376<span class="sd">            Contains all the parameters of CONTROL file and</span>
377<span class="sd">            command line.</span>
378<span class="sd">            For more information about format and content of the parameter</span>
379<span class="sd">            see documentation.</span>
380
381<span class="sd">    @Return:</span>
382<span class="sd">        &lt;nothing&gt;</span>
383<span class="sd">    &#39;&#39;&#39;</span>
384
385    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;clean_up&quot;</span><span class="p">)</span>
386
387    <span class="n">cleanlist</span> <span class="o">=</span> <span class="n">glob</span><span class="o">.</span><span class="n">glob</span><span class="p">(</span><span class="n">c</span><span class="o">.</span><span class="n">inputdir</span> <span class="o">+</span> <span class="s2">&quot;/*&quot;</span><span class="p">)</span>
388    <span class="k">for</span> <span class="n">clist</span> <span class="ow">in</span> <span class="n">cleanlist</span><span class="p">:</span>
389        <span class="k">if</span> <span class="n">c</span><span class="o">.</span><span class="n">prefix</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">clist</span><span class="p">:</span>
390            <span class="n">silent_remove</span><span class="p">(</span><span class="n">clist</span><span class="p">)</span>
391        <span class="k">if</span> <span class="n">c</span><span class="o">.</span><span class="n">ecapi</span> <span class="ow">is</span> <span class="kc">False</span> <span class="ow">and</span> <span class="p">(</span><span class="n">c</span><span class="o">.</span><span class="n">ectrans</span> <span class="o">==</span> <span class="s1">&#39;1&#39;</span> <span class="ow">or</span> <span class="n">c</span><span class="o">.</span><span class="n">ecstorage</span> <span class="o">==</span> <span class="s1">&#39;1&#39;</span><span class="p">):</span>
392            <span class="n">silent_remove</span><span class="p">(</span><span class="n">clist</span><span class="p">)</span>
393
394    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Done&quot;</span><span class="p">)</span>
395
396    <span class="k">return</span></div>
397
398
399<div class="viewcode-block" id="my_error"><a class="viewcode-back" href="../code.html#tools.my_error">[docs]</a><span class="k">def</span> <span class="nf">my_error</span><span class="p">(</span><span class="n">users</span><span class="p">,</span> <span class="n">message</span><span class="o">=</span><span class="s1">&#39;ERROR&#39;</span><span class="p">):</span>
400    <span class="sd">&#39;&#39;&#39;</span>
401<span class="sd">    @Description:</span>
402<span class="sd">        Prints a specified error message which can be passed to the function</span>
403<span class="sd">        before exiting the program.</span>
404
405<span class="sd">    @Input:</span>
406<span class="sd">        user: list of strings</span>
407<span class="sd">            Contains all email addresses which should be notified.</span>
408<span class="sd">            It might also contain just the ecmwf user name which wil trigger</span>
409<span class="sd">            mailing to the associated email address for this user.</span>
410
411<span class="sd">        message: string, optional</span>
412<span class="sd">            Error message. Default value is &quot;ERROR&quot;.</span>
413
414<span class="sd">    @Return:</span>
415<span class="sd">        &lt;nothing&gt;</span>
416<span class="sd">    &#39;&#39;&#39;</span>
417
418    <span class="nb">print</span><span class="p">(</span><span class="n">message</span><span class="p">)</span>
419
420    <span class="c1"># comment if user does not want email notification directly from python</span>
421    <span class="k">for</span> <span class="n">user</span> <span class="ow">in</span> <span class="n">users</span><span class="p">:</span>
422        <span class="k">if</span> <span class="s1">&#39;$</span><span class="si">{USER}</span><span class="s1">&#39;</span> <span class="ow">in</span> <span class="n">user</span><span class="p">:</span>
423            <span class="n">user</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">getenv</span><span class="p">(</span><span class="s1">&#39;USER&#39;</span><span class="p">)</span>
424        <span class="k">try</span><span class="p">:</span>
425            <span class="n">p</span> <span class="o">=</span> <span class="n">subprocess</span><span class="o">.</span><span class="n">Popen</span><span class="p">([</span><span class="s1">&#39;mail&#39;</span><span class="p">,</span> <span class="s1">&#39;-s flex_extract_v7.1 ERROR&#39;</span><span class="p">,</span>
426                                  <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">expandvars</span><span class="p">(</span><span class="n">user</span><span class="p">)],</span>
427                                 <span class="n">stdin</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">PIPE</span><span class="p">,</span>
428                                 <span class="n">stdout</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">PIPE</span><span class="p">,</span>
429                                 <span class="n">stderr</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">PIPE</span><span class="p">,</span>
430                                 <span class="n">bufsize</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
431            <span class="n">trace</span> <span class="o">=</span> <span class="s1">&#39;</span><span class="se">\n</span><span class="s1">&#39;</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">traceback</span><span class="o">.</span><span class="n">format_stack</span><span class="p">())</span>
432            <span class="n">pout</span> <span class="o">=</span> <span class="n">p</span><span class="o">.</span><span class="n">communicate</span><span class="p">(</span><span class="nb">input</span><span class="o">=</span><span class="n">message</span> <span class="o">+</span> <span class="s1">&#39;</span><span class="se">\n\n</span><span class="s1">&#39;</span> <span class="o">+</span> <span class="n">trace</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span>
433        <span class="k">except</span> <span class="ne">ValueError</span> <span class="k">as</span> <span class="n">e</span><span class="p">:</span>
434            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;ERROR: &#39;</span><span class="p">,</span> <span class="n">e</span><span class="p">)</span>
435            <span class="n">sys</span><span class="o">.</span><span class="n">exit</span><span class="p">(</span><span class="s1">&#39;Email could not be sent!&#39;</span><span class="p">)</span>
436        <span class="k">else</span><span class="p">:</span>
437            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;Email sent to &#39;</span> <span class="o">+</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">expandvars</span><span class="p">(</span><span class="n">user</span><span class="p">)</span> <span class="o">+</span> <span class="s1">&#39; &#39;</span> <span class="o">+</span>
438                  <span class="n">pout</span><span class="o">.</span><span class="n">decode</span><span class="p">())</span>
439
440    <span class="n">sys</span><span class="o">.</span><span class="n">exit</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span>
441
442    <span class="k">return</span></div>
443
444
445<div class="viewcode-block" id="normal_exit"><a class="viewcode-back" href="../code.html#tools.normal_exit">[docs]</a><span class="k">def</span> <span class="nf">normal_exit</span><span class="p">(</span><span class="n">users</span><span class="p">,</span> <span class="n">message</span><span class="o">=</span><span class="s1">&#39;Done!&#39;</span><span class="p">):</span>
446    <span class="sd">&#39;&#39;&#39;</span>
447<span class="sd">    @Description:</span>
448<span class="sd">        Prints a specific exit message which can be passed to the function.</span>
449
450<span class="sd">    @Input:</span>
451<span class="sd">        user: list of strings</span>
452<span class="sd">            Contains all email addresses which should be notified.</span>
453<span class="sd">            It might also contain just the ecmwf user name which wil trigger</span>
454<span class="sd">            mailing to the associated email address for this user.</span>
455
456<span class="sd">        message: string, optional</span>
457<span class="sd">            Message for exiting program. Default value is &quot;Done!&quot;.</span>
458
459<span class="sd">    @Return:</span>
460<span class="sd">        &lt;nothing&gt;</span>
461
462<span class="sd">    &#39;&#39;&#39;</span>
463    <span class="nb">print</span><span class="p">(</span><span class="n">message</span><span class="p">)</span>
464
465    <span class="c1"># comment if user does not want notification directly from python</span>
466    <span class="k">for</span> <span class="n">user</span> <span class="ow">in</span> <span class="n">users</span><span class="p">:</span>
467        <span class="k">if</span> <span class="s1">&#39;$</span><span class="si">{USER}</span><span class="s1">&#39;</span> <span class="ow">in</span> <span class="n">user</span><span class="p">:</span>
468            <span class="n">user</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">getenv</span><span class="p">(</span><span class="s1">&#39;USER&#39;</span><span class="p">)</span>
469        <span class="k">try</span><span class="p">:</span>
470            <span class="n">p</span> <span class="o">=</span> <span class="n">subprocess</span><span class="o">.</span><span class="n">Popen</span><span class="p">([</span><span class="s1">&#39;mail&#39;</span><span class="p">,</span> <span class="s1">&#39;-s flex_extract_v7.1 normal exit&#39;</span><span class="p">,</span>
471                                  <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">expandvars</span><span class="p">(</span><span class="n">user</span><span class="p">)],</span>
472                                 <span class="n">stdin</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">PIPE</span><span class="p">,</span>
473                                 <span class="n">stdout</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">PIPE</span><span class="p">,</span>
474                                 <span class="n">stderr</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">PIPE</span><span class="p">,</span>
475                                 <span class="n">bufsize</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
476            <span class="n">pout</span> <span class="o">=</span> <span class="n">p</span><span class="o">.</span><span class="n">communicate</span><span class="p">(</span><span class="nb">input</span><span class="o">=</span><span class="n">message</span><span class="o">+</span><span class="s1">&#39;</span><span class="se">\n\n</span><span class="s1">&#39;</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span>
477        <span class="k">except</span> <span class="ne">ValueError</span> <span class="k">as</span> <span class="n">e</span><span class="p">:</span>
478            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;ERROR: &#39;</span><span class="p">,</span> <span class="n">e</span><span class="p">)</span>
479            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;Email could not be sent!&#39;</span><span class="p">)</span>
480        <span class="k">else</span><span class="p">:</span>
481            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;Email sent to &#39;</span> <span class="o">+</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">expandvars</span><span class="p">(</span><span class="n">user</span><span class="p">)</span> <span class="o">+</span> <span class="s1">&#39; &#39;</span> <span class="o">+</span>
482                  <span class="n">pout</span><span class="o">.</span><span class="n">decode</span><span class="p">())</span>
483
484    <span class="k">return</span></div>
485
486
487<div class="viewcode-block" id="product"><a class="viewcode-back" href="../code.html#tools.product">[docs]</a><span class="k">def</span> <span class="nf">product</span><span class="p">(</span><span class="o">*</span><span class="n">args</span><span class="p">,</span> <span class="o">**</span><span class="n">kwds</span><span class="p">):</span>
488    <span class="sd">&#39;&#39;&#39;</span>
489<span class="sd">    @Description:</span>
490<span class="sd">        This method is taken from an example at the ECMWF wiki website.</span>
491<span class="sd">        https://software.ecmwf.int/wiki/display/GRIB/index.py; 2018-03-16</span>
492
493<span class="sd">        This method combines the single characters of the passed arguments</span>
494<span class="sd">        with each other. So that each character of each argument value</span>
495<span class="sd">        will be combined with each character of the other arguments as a tuple.</span>
496
497<span class="sd">        Example:</span>
498<span class="sd">        product(&#39;ABCD&#39;, &#39;xy&#39;) --&gt; Ax Ay Bx By Cx Cy Dx Dy</span>
499<span class="sd">        product(range(2), repeat = 3) --&gt; 000 001 010 011 100 101 110 111</span>
500
501<span class="sd">    @Input:</span>
502<span class="sd">        *args: tuple</span>
503<span class="sd">            Positional arguments (arbitrary number).</span>
504
505<span class="sd">        **kwds: dictionary</span>
506<span class="sd">            Contains all the keyword arguments from *args.</span>
507
508<span class="sd">    @Return:</span>
509<span class="sd">        prod: tuple</span>
510<span class="sd">            Return will be done with &quot;yield&quot;. A tuple of combined arguments.</span>
511<span class="sd">            See example in description above.</span>
512<span class="sd">    &#39;&#39;&#39;</span>
513    <span class="n">pools</span> <span class="o">=</span> <span class="nb">map</span><span class="p">(</span><span class="nb">tuple</span><span class="p">,</span> <span class="n">args</span><span class="p">)</span> <span class="o">*</span> <span class="n">kwds</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s1">&#39;repeat&#39;</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
514    <span class="n">result</span> <span class="o">=</span> <span class="p">[[]]</span>
515    <span class="k">for</span> <span class="n">pool</span> <span class="ow">in</span> <span class="n">pools</span><span class="p">:</span>
516        <span class="n">result</span> <span class="o">=</span> <span class="p">[</span><span class="n">x</span> <span class="o">+</span> <span class="p">[</span><span class="n">y</span><span class="p">]</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">result</span> <span class="k">for</span> <span class="n">y</span> <span class="ow">in</span> <span class="n">pool</span><span class="p">]</span>
517    <span class="k">for</span> <span class="n">prod</span> <span class="ow">in</span> <span class="n">result</span><span class="p">:</span>
518        <span class="k">yield</span> <span class="nb">tuple</span><span class="p">(</span><span class="n">prod</span><span class="p">)</span>
519
520    <span class="k">return</span></div>
521
522
523<div class="viewcode-block" id="silent_remove"><a class="viewcode-back" href="../code.html#tools.silent_remove">[docs]</a><span class="k">def</span> <span class="nf">silent_remove</span><span class="p">(</span><span class="n">filename</span><span class="p">):</span>
524    <span class="sd">&#39;&#39;&#39;</span>
525<span class="sd">    @Description:</span>
526<span class="sd">        Remove file if it exists.</span>
527<span class="sd">        The function does not fail if the file does not exist.</span>
528
529<span class="sd">    @Input:</span>
530<span class="sd">        filename: string</span>
531<span class="sd">            The name of the file to be removed without notification.</span>
532
533<span class="sd">    @Return:</span>
534<span class="sd">        &lt;nothing&gt;</span>
535<span class="sd">    &#39;&#39;&#39;</span>
536    <span class="k">try</span><span class="p">:</span>
537        <span class="n">os</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">filename</span><span class="p">)</span>
538    <span class="k">except</span> <span class="ne">OSError</span> <span class="k">as</span> <span class="n">e</span><span class="p">:</span>
539        <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">errno</span> <span class="o">!=</span> <span class="n">errno</span><span class="o">.</span><span class="n">ENOENT</span><span class="p">:</span>
540            <span class="c1"># errno.ENOENT  =  no such file or directory</span>
541            <span class="k">raise</span>  <span class="c1"># re-raise exception if a different error occured</span>
542
543    <span class="k">return</span></div>
544
545
546<div class="viewcode-block" id="init128"><a class="viewcode-back" href="../code.html#tools.init128">[docs]</a><span class="k">def</span> <span class="nf">init128</span><span class="p">(</span><span class="n">filepath</span><span class="p">):</span>
547    <span class="sd">&#39;&#39;&#39;</span>
548<span class="sd">    @Description:</span>
549<span class="sd">        Opens and reads the grib file with table 128 information.</span>
550
551<span class="sd">    @Input:</span>
552<span class="sd">        filepath: string</span>
553<span class="sd">            Path to file of ECMWF grib table number 128.</span>
554
555<span class="sd">    @Return:</span>
556<span class="sd">        table128: dictionary</span>
557<span class="sd">            Contains the ECMWF grib table 128 information.</span>
558<span class="sd">            The key is the parameter number and the value is the</span>
559<span class="sd">            short name of the parameter.</span>
560<span class="sd">    &#39;&#39;&#39;</span>
561    <span class="n">table128</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>
562    <span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="n">filepath</span><span class="p">)</span> <span class="k">as</span> <span class="n">f</span><span class="p">:</span>
563        <span class="n">fdata</span> <span class="o">=</span> <span class="n">f</span><span class="o">.</span><span class="n">read</span><span class="p">()</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">)</span>
564    <span class="k">for</span> <span class="n">data</span> <span class="ow">in</span> <span class="n">fdata</span><span class="p">:</span>
565        <span class="k">if</span> <span class="n">data</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">!=</span> <span class="s1">&#39;!&#39;</span><span class="p">:</span>
566            <span class="n">table128</span><span class="p">[</span><span class="n">data</span><span class="p">[</span><span class="mi">0</span><span class="p">:</span><span class="mi">3</span><span class="p">]]</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="mi">59</span><span class="p">:</span><span class="mi">64</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span>
567
568    <span class="k">return</span> <span class="n">table128</span></div>
569
570
571<div class="viewcode-block" id="to_param_id"><a class="viewcode-back" href="../code.html#tools.to_param_id">[docs]</a><span class="k">def</span> <span class="nf">to_param_id</span><span class="p">(</span><span class="n">pars</span><span class="p">,</span> <span class="n">table</span><span class="p">):</span>
572    <span class="sd">&#39;&#39;&#39;</span>
573<span class="sd">    @Description:</span>
574<span class="sd">        Transform parameter names to parameter ids</span>
575<span class="sd">        with ECMWF grib table 128.</span>
576
577<span class="sd">    @Input:</span>
578<span class="sd">        pars: string</span>
579<span class="sd">            Addpar argument from CONTROL file in the format of</span>
580<span class="sd">            parameter names instead of ids. The parameter short</span>
581<span class="sd">            names are sepearted with &quot;/&quot; and they are passed as</span>
582<span class="sd">            one single string.</span>
583
584<span class="sd">        table: dictionary</span>
585<span class="sd">            Contains the ECMWF grib table 128 information.</span>
586<span class="sd">            The key is the parameter number and the value is the</span>
587<span class="sd">            short name of the parameter.</span>
588
589<span class="sd">    @Return:</span>
590<span class="sd">        ipar: list of integer</span>
591<span class="sd">            List of addpar parameters from CONTROL file transformed to</span>
592<span class="sd">            parameter ids in the format of integer.</span>
593<span class="sd">    &#39;&#39;&#39;</span>
594    <span class="n">cpar</span> <span class="o">=</span> <span class="n">pars</span><span class="o">.</span><span class="n">upper</span><span class="p">()</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">&#39;/&#39;</span><span class="p">)</span>
595    <span class="n">ipar</span> <span class="o">=</span> <span class="p">[]</span>
596    <span class="k">for</span> <span class="n">par</span> <span class="ow">in</span> <span class="n">cpar</span><span class="p">:</span>
597        <span class="k">for</span> <span class="n">k</span><span class="p">,</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">table</span><span class="o">.</span><span class="n">iteritems</span><span class="p">():</span>
598            <span class="k">if</span> <span class="n">par</span> <span class="o">==</span> <span class="n">k</span> <span class="ow">or</span> <span class="n">par</span> <span class="o">==</span> <span class="n">v</span><span class="p">:</span>
599                <span class="n">ipar</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="nb">int</span><span class="p">(</span><span class="n">k</span><span class="p">))</span>
600                <span class="k">break</span>
601        <span class="k">else</span><span class="p">:</span>
602            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;Warning: par &#39;</span> <span class="o">+</span> <span class="n">par</span> <span class="o">+</span> <span class="s1">&#39; not found in table 128&#39;</span><span class="p">)</span>
603
604    <span class="k">return</span> <span class="n">ipar</span></div>
605
606<div class="viewcode-block" id="get_list_as_string"><a class="viewcode-back" href="../code.html#tools.get_list_as_string">[docs]</a><span class="k">def</span> <span class="nf">get_list_as_string</span><span class="p">(</span><span class="n">list_obj</span><span class="p">,</span> <span class="n">concatenate_sign</span><span class="o">=</span><span class="s1">&#39;, &#39;</span><span class="p">):</span>
607    <span class="sd">&#39;&#39;&#39;</span>
608<span class="sd">    @Description:</span>
609<span class="sd">        Converts a list of arbitrary content into a single string.</span>
610
611<span class="sd">    @Input:</span>
612<span class="sd">        list_obj: list</span>
613<span class="sd">            A list with arbitrary content.</span>
614
615<span class="sd">        concatenate_sign: string, optional</span>
616<span class="sd">            A string which is used to concatenate the single</span>
617<span class="sd">            list elements. Default value is &quot;, &quot;.</span>
618
619<span class="sd">    @Return:</span>
620<span class="sd">        str_of_list: string</span>
621<span class="sd">            The content of the list as a single string.</span>
622<span class="sd">    &#39;&#39;&#39;</span>
623
624    <span class="n">str_of_list</span> <span class="o">=</span> <span class="n">concatenate_sign</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">l</span><span class="p">)</span> <span class="k">for</span> <span class="n">l</span> <span class="ow">in</span> <span class="n">list_obj</span><span class="p">)</span>
625
626    <span class="k">return</span> <span class="n">str_of_list</span></div>
627
628<div class="viewcode-block" id="make_dir"><a class="viewcode-back" href="../code.html#tools.make_dir">[docs]</a><span class="k">def</span> <span class="nf">make_dir</span><span class="p">(</span><span class="n">directory</span><span class="p">):</span>
629    <span class="sd">&#39;&#39;&#39;</span>
630<span class="sd">    @Description:</span>
631<span class="sd">        Creates a directory and gives a warning if the directory</span>
632<span class="sd">        already exists. The program stops only if there is another problem.</span>
633
634<span class="sd">    @Input:</span>
635<span class="sd">        directory: string</span>
636<span class="sd">            The directory name including the path which should be created.</span>
637
638<span class="sd">    @Return:</span>
639<span class="sd">        &lt;nothing&gt;</span>
640<span class="sd">    &#39;&#39;&#39;</span>
641    <span class="k">try</span><span class="p">:</span>
642        <span class="n">os</span><span class="o">.</span><span class="n">makedirs</span><span class="p">(</span><span class="n">directory</span><span class="p">)</span>
643    <span class="k">except</span> <span class="ne">OSError</span> <span class="k">as</span> <span class="n">e</span><span class="p">:</span>
644        <span class="k">if</span> <span class="n">e</span><span class="o">.</span><span class="n">errno</span> <span class="o">!=</span> <span class="n">errno</span><span class="o">.</span><span class="n">EEXIST</span><span class="p">:</span>
645            <span class="c1"># errno.EEXIST = directory already exists</span>
646            <span class="k">raise</span> <span class="c1"># re-raise exception if a different error occured</span>
647        <span class="k">else</span><span class="p">:</span>
648            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;WARNING: Directory </span><span class="si">{0}</span><span class="s1"> already exists!&#39;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">directory</span><span class="p">))</span>
649
650    <span class="k">return</span></div>
651
652<div class="viewcode-block" id="put_file_to_ecserver"><a class="viewcode-back" href="../code.html#tools.put_file_to_ecserver">[docs]</a><span class="k">def</span> <span class="nf">put_file_to_ecserver</span><span class="p">(</span><span class="n">ecd</span><span class="p">,</span> <span class="n">filename</span><span class="p">,</span> <span class="n">target</span><span class="p">,</span> <span class="n">ecuid</span><span class="p">,</span> <span class="n">ecgid</span><span class="p">):</span>
653    <span class="sd">&#39;&#39;&#39;</span>
654<span class="sd">    @Description:</span>
655<span class="sd">        Uses the ecaccess-file-put command to send a file to the ECMWF servers.</span>
656
657<span class="sd">        NOTE:</span>
658<span class="sd">        The return value is just for testing reasons. It does not have</span>
659<span class="sd">        to be used from the calling function since the whole error handling</span>
660<span class="sd">        is done in here.</span>
661
662<span class="sd">    @Input:</span>
663<span class="sd">        ecd: string</span>
664<span class="sd">            The path were the file is stored.</span>
665
666<span class="sd">        filename: string</span>
667<span class="sd">            The name of the file to send to the ECMWF server.</span>
668
669<span class="sd">        target: string</span>
670<span class="sd">            The target queue where the file should be sent to.</span>
671
672<span class="sd">        ecuid: string</span>
673<span class="sd">            The user id on ECMWF server.</span>
674
675<span class="sd">        ecgid: string</span>
676<span class="sd">            The group id on ECMWF server.</span>
677
678<span class="sd">    @Return:</span>
679<span class="sd">        rcode: string</span>
680<span class="sd">            Resulting code of command execution. If successful the string</span>
681<span class="sd">            will be empty.</span>
682<span class="sd">    &#39;&#39;&#39;</span>
683
684    <span class="k">try</span><span class="p">:</span>
685        <span class="n">rcode</span> <span class="o">=</span> <span class="n">subprocess</span><span class="o">.</span><span class="n">check_output</span><span class="p">([</span><span class="s1">&#39;ecaccess-file-put&#39;</span><span class="p">,</span>
686                                          <span class="n">ecd</span> <span class="o">+</span> <span class="s1">&#39;/&#39;</span> <span class="o">+</span> <span class="n">filename</span><span class="p">,</span>
687                                          <span class="n">target</span> <span class="o">+</span> <span class="s1">&#39;:/home/ms/&#39;</span> <span class="o">+</span>
688                                          <span class="n">ecgid</span> <span class="o">+</span> <span class="s1">&#39;/&#39;</span> <span class="o">+</span> <span class="n">ecuid</span> <span class="o">+</span>
689                                          <span class="s1">&#39;/&#39;</span> <span class="o">+</span> <span class="n">filename</span><span class="p">],</span>
690                                         <span class="n">stderr</span><span class="o">=</span><span class="n">subprocess</span><span class="o">.</span><span class="n">STDOUT</span><span class="p">)</span>
691    <span class="k">except</span> <span class="n">subprocess</span><span class="o">.</span><span class="n">CalledProcessError</span> <span class="k">as</span> <span class="n">e</span><span class="p">:</span>
692        <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;... ERROR CODE:</span><span class="se">\n</span><span class="s1"> ... &#39;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">e</span><span class="o">.</span><span class="n">returncode</span><span class="p">))</span>
693        <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;... ERROR MESSAGE:</span><span class="se">\n</span><span class="s1"> ... &#39;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">e</span><span class="p">))</span>
694
695        <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">... Do you have a valid ecaccess certification key?&#39;</span><span class="p">)</span>
696        <span class="n">sys</span><span class="o">.</span><span class="n">exit</span><span class="p">(</span><span class="s1">&#39;... ECACCESS-FILE-PUT FAILED!&#39;</span><span class="p">)</span>
697
698    <span class="k">return</span> <span class="n">rcode</span></div>
699
700<div class="viewcode-block" id="submit_job_to_ecserver"><a class="viewcode-back" href="../code.html#tools.submit_job_to_ecserver">[docs]</a><span class="k">def</span> <span class="nf">submit_job_to_ecserver</span><span class="p">(</span><span class="n">target</span><span class="p">,</span> <span class="n">jobname</span><span class="p">):</span>
701    <span class="sd">&#39;&#39;&#39;</span>
702<span class="sd">    @Description:</span>
703<span class="sd">        Uses ecaccess-job-submit command to submit a job to the ECMWF server.</span>
704
705<span class="sd">        NOTE:</span>
706<span class="sd">        The return value is just for testing reasons. It does not have</span>
707<span class="sd">        to be used from the calling function since the whole error handling</span>
708<span class="sd">        is done in here.</span>
709
710<span class="sd">    @Input:</span>
711<span class="sd">        target: string</span>
712<span class="sd">            The target where the file should be sent to, e.g. the queue.</span>
713
714<span class="sd">        jobname: string</span>
715<span class="sd">            The name of the jobfile to be submitted to the ECMWF server.</span>
716
717<span class="sd">    @Return:</span>
718<span class="sd">        rcode: string</span>
719<span class="sd">            Resulting code of command execution. If successful the string</span>
720<span class="sd">            will contain an integer number, representing the id of the job</span>
721<span class="sd">            at the ecmwf server.</span>
722<span class="sd">    &#39;&#39;&#39;</span>
723
724    <span class="k">try</span><span class="p">:</span>
725        <span class="n">rcode</span> <span class="o">=</span> <span class="n">subprocess</span><span class="o">.</span><span class="n">check_output</span><span class="p">([</span><span class="s1">&#39;ecaccess-job-submit&#39;</span><span class="p">,</span>
726                                         <span class="s1">&#39;-queueName&#39;</span><span class="p">,</span> <span class="n">target</span><span class="p">,</span>
727                                         <span class="n">jobname</span><span class="p">])</span>
728    <span class="k">except</span> <span class="n">subprocess</span><span class="o">.</span><span class="n">CalledProcessError</span> <span class="k">as</span> <span class="n">e</span><span class="p">:</span>
729        <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;... ERROR CODE:</span><span class="se">\n</span><span class="s1"> ... &#39;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">e</span><span class="o">.</span><span class="n">returncode</span><span class="p">))</span>
730        <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;... ERROR MESSAGE:</span><span class="se">\n</span><span class="s1"> ... &#39;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">e</span><span class="p">))</span>
731
732
733        <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">... Do you have a valid ecaccess certification key?&#39;</span><span class="p">)</span>
734        <span class="n">sys</span><span class="o">.</span><span class="n">exit</span><span class="p">(</span><span class="s1">&#39;... ECACCESS-JOB-SUBMIT FAILED!&#39;</span><span class="p">)</span>
735
736    <span class="k">return</span> <span class="n">rcode</span></div>
737</pre></div>
738
739           </div>
740           
741          </div>
742          <footer>
743 
744
745  <hr/>
746
747  <div role="contentinfo">
748    <p>
749        &copy; Copyright 2018, Anne Philipp and Leopold Haimberger.
750
751    </p>
752  </div>
753  Built with <a href="http://sphinx-doc.org/">Sphinx</a> using a <a href="https://github.com/rtfd/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
754
755</footer>
756
757        </div>
758      </div>
759
760    </section>
761
762  </div>
763 
764
765
766 
767
768    <script type="text/javascript">
769        var DOCUMENTATION_OPTIONS = {
770            URL_ROOT:'../',
771            VERSION:'7.1 alpha',
772            LANGUAGE:'None',
773            COLLAPSE_INDEX:false,
774            FILE_SUFFIX:'.html',
775            HAS_SOURCE:  true,
776            SOURCELINK_SUFFIX: '.txt'
777        };
778    </script>
779      <script type="text/javascript" src="../_static/jquery.js"></script>
780      <script type="text/javascript" src="../_static/underscore.js"></script>
781      <script type="text/javascript" src="../_static/doctools.js"></script>
782      <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
783
784 
785
786  <script type="text/javascript" src="../_static/js/theme.js"></script>
787
788  <script type="text/javascript">
789      jQuery(function () {
790          SphinxRtdTheme.Navigation.enable(true);
791      });
792  </script> 
793
794</body>
795</html>
Note: See TracBrowser for help on using the repository browser.
hosted by ZAMG