Skip to content
Snippets Groups Projects
physicalParameter.py 2.86 KiB
Newer Older
import csv
import shelve
import sys
import logging
import argparse
    '''
    This class read a csv file describing physical parameter with ROSCOP codification
    '''

    # constructor with values by default
    def __init__(self, file):
        self.file = file
        self.__hash = {}
        self.read()

    # call by print()
jacques.grelet_ird.fr's avatar
jacques.grelet_ird.fr committed
    def __str__(self):
        ''' overload string representation '''
        return 'Class Roscop, file: %s, size = %d' % (self.file, len(self))
    def __getitem__(self, name):
        ''' overload r[key] '''
        return self.__hash[name]
jacques Grelet's avatar
jacques Grelet committed

    def __repr__(self):
        ''' overload print() '''
jacques Grelet's avatar
jacques Grelet committed
        return super().__repr__()

    def __len__(self):
        ''' overload len() '''
        return len(self.__hash)

    def displayCode(self, theKey):
        print("%s :" % theKey)
        print(self[theKey])
    def returnCode(self, theKey):
        return(self[theKey])

    # read code roscop file
    def read(self):
        with open(self.file, 'rt') as f:
            reader = csv.DictReader(f, delimiter=';')
            for row in reader:
jacques.grelet_ird.fr's avatar
jacques.grelet_ird.fr committed
                theKey = row[reader.fieldnames[0]]
                for k in reader.fieldnames:
                    # if the value of key is empty
                    if row[k] == '':
                        # remove the key
                        row.pop(k)
                    else:
                        #logging.debug(" %s -> %s: %s" % (theKey, k, row[k]))
                        logging.debug(
                            " {} -> {}: {}".format(theKey, k, row[k]))
                self.__hash[theKey] = row

# for testing in standalone context
# ---------------------------------
if __name__ == "__main__":

    # display extra logging info
    # see: https://stackoverflow.com/questions/14097061/easier-way-to-enable-verbose-logging
jacques Grelet's avatar
jacques Grelet committed
    # https://docs.python.org/2/howto/argparse.html
    parser = argparse.ArgumentParser(
        description='This class Roscop parse a csv file describing physical parameter codification')
    parser.add_argument("-d", "--debug", help="display debug informations",
                        action="store_true")
jacques Grelet's avatar
jacques Grelet committed
    parser.add_argument("-k", "--key", nargs='+',
                        help="display dictionary for key(s), example -k TEMP [PSAL ...]")
    parser.add_argument("file", type=str, help="the csv file to parse")
    args = parser.parse_args()
    if args.debug:
        logging.basicConfig(
            format='%(levelname)s:%(message)s', level=logging.DEBUG)

    # Read the csv file and create an instance of Roscop class
    r = Roscop(args.file)
jacques Grelet's avatar
jacques Grelet committed
    # r = Roscop("code_roscop.csv")
    # r.read()
    print(r)

    # get -k arg(s) list
    key = args.key
    # if args list is empty, key contain NoneType
    if key is not None:
        for k in key:
            r.displayCode(k)
    print(r.returnCode(key[0])['key'])
jacques Grelet's avatar
jacques Grelet committed
    # print(r[key])