Project

General

Profile

1
PyMetacat 
2
Python client library to work with Metacat XML Databases.
3
Author: Matthew Perry
4
Date: 12/06/2006
5

    
6
Introduction
7
-------------
8
Metacat is a flexible XML database. It can store, search and rerieve XML documents of any schema and it used primarily for storing metadata documents. This library provides a python interface to any Metacat server allowing you to add, insert, update, delete and query documents.
9

    
10

    
11
Installation
12
------------
13

    
14
To install pymetcat, copy the metacat.py file into your python site-packages directory (eg. /usr/lib/python2.4/site-packages) or anywhere in $PYTHONPATH  including the current working directory.
15

    
16

    
17
Examples
18
------------
19

    
20
Along with transferEml.py (a full working example of pymetacat usage), here are some basic usage examples:
21

    
22

    
23

    
24
# Load the metacat library
25
import metacat
26

    
27
# Initialize a metacat client connection
28
mc = metacat.MetacatClient('www.server.net','/context/metacat')
29

    
30
# Inspect the methods available through the MetacatClient object
31
dir(mc)
32

    
33
# Print the url
34
print mc.getMetacatUrl()
35

    
36
# Login
37
response = mc.login('uid=user,o=ORG,dc=ecoinformatics,dc=org','PassW0Rd!')
38
print "login : ", response
39

    
40
# Read the eml 
41
docid = 'org.99.4.1'
42
eml = mc.read(docid)
43
print eml
44

    
45
# Insert the read document as a new copy w/ new docid
46
newdocid = 'anotherorg.905'
47
response = mc.insert(newdocid + ".1",eml)
48
print response
49

    
50
# Make some change to the xml text and update it
51
eml.replace("Serengeti", "Some other")
52
response = mc.update(newdocid + ".2",eml)
53
print response
54

    
55
# Delete the document
56
response = mc.delete(newdocid + ".2")
57
print "DELETE"
58
print response
59

    
60

    
61
pathquery = """
62
   <pathquery version="1.0">
63
      <meta_file_id>unspecified</meta_file_id>
64
      <querytitle>unspecified</querytitle>
65
      <returnfield>dataset/title</returnfield>
66
      <returndoctype></returndoctype>
67
      <querygroup operator="UNION">
68
        <queryterm casesensitive="false" searchmode="contains">
69
          <value>%</value>
70
        </queryterm>
71
        <queryterm casesensitive="false" searchmode="contains">
72
          <value>Africa</value>
73
          <pathexpr>keyword</pathexpr>
74
        </queryterm>
75
      </querygroup>
76
    </pathquery> 
77
"""
78
response = mc.squery(pathquery)
79
print response
80

    
81
response = mc.logout()
82
print "logout : ", response
(1-1/3)