File: query.py

package info (click to toggle)
python-enthoughtbase 3.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 960 kB
  • ctags: 1,034
  • sloc: python: 6,104; makefile: 9; sh: 5
file content (62 lines) | stat: -rw-r--r-- 1,950 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#------------------------------------------------------------------------------
# Copyright (c) 2005, Enthought, Inc.
# All rights reserved.
# 
# This software is provided without warranty under the terms of the BSD
# license included in enthought/LICENSE.txt and may be redistributed only
# under the conditions described in the aforementioned license.  The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
# Thanks for using Enthought open source!
# 
# Author: Enthought, Inc.
# Description: <Enthought util package component>
#------------------------------------------------------------------------------
def query(data, var_names, expression):
    """ Extract all of the items in the dictionary that matches the user
    specified expression.
    
    data is the dictionary to be queried
    
    var_names describes the variables in the key that can be used in the 
    expression eg (case, marker)
    
    expression is a python expression eg case == 'oil' and marker = 'top sand' 
    """
    matches = {}
    
    for key in data.keys():
        print key
        ns = _build_namespace(var_names, key)
        print ns
        
        if eval(expression, ns):
            matches[key] = data[key]
            
    return matches
    
def _build_namespace(var_names, key):
    
    namespace = {}
    for name, value in zip(var_names, key):
        namespace[name] = value
        
    return namespace
    
    
if __name__ == "__main__" or __name__ == 'PyCrust-Shell':
    
    db = {}
    db[('oil', 'A')] = 1    
    db[('oil', 'B')] = 2
    db[('gas', 'A')] = 3 
    db[('gas', 'B')] = 4 
    
    result = query(db, ('fluid', 'attribute'), 'fluid == "oil"')
    
    for name, value in result.iteritems():
        print "%s %s" % (name, value)
        
    result = query(db, ('fluid', 'attribute'), 'attribute > 2')
    
    for name, value in result.iteritems():
        print "%s %s" % (name, value)