Commit 517a70c3 authored by Joanne Hugé's avatar Joanne Hugé

Add option to update all metadata from measures of a measure type

parent 937e4442
...@@ -112,16 +112,35 @@ class MeasureSetHandler: ...@@ -112,16 +112,35 @@ class MeasureSetHandler:
else: else:
print("{}{} doesn't exist".format(mtype, mid)) print("{}{} doesn't exist".format(mtype, mid))
def modify_metadata(self, mtype, mid): def update_metadata(self, mtype, mid, metadata, removed_metadata):
if mtype in self.measure_sets and mid in self.measure_sets[mtype]['ids']: if mtype in self.measure_sets and mid in self.measure_sets[mtype]['ids']:
measure_set = self.get_measure_set("{}{}".format(mtype, mid)) measure_set = self.get_measure_set("{}{}".format(mtype, mid))
metadata = measure_set.input_metadata() measure_set.update_metadata(metadata, removed_metadata)
measure_set.metadata.update(metadata)
measure_file_name = "{}/{}{}.json".format(MeasureSetHandler.measures_dir, mtype, mid) measure_file_name = "{}/{}{}.json".format(MeasureSetHandler.measures_dir, mtype, mid)
measure_set.export_to_json(measure_file_name) measure_set.export_to_json(measure_file_name)
else: else:
print("{}{} doesn't exist".format(mtype, mid)) print("{}{} doesn't exist".format(mtype, mid))
def modify_metadata(self, mtype, mid=-1):
update_all = (mid == -1)
if mtype in self.measure_sets:
measure_ids = self.measure_sets[mtype]['ids']
else:
print("There are no measures of type {}".format(mtype))
return
if update_all:
mid = measure_ids[0]
if mtype in self.measure_sets and mid in measure_ids:
measure_set = self.get_measure_set("{}{}".format(mtype, mid))
metadata, removed_metadata = measure_set.input_metadata()
self.update_metadata(mtype, mid, metadata, removed_metadata)
if update_all:
for measure_id in measure_ids:
self.update_metadata(mtype, measure_id, metadata, removed_metadata)
else:
print("{}{} doesn't exist".format(mtype, mid))
def remove_all(self): def remove_all(self):
for mtype in self.measure_sets: for mtype in self.measure_sets:
while True: while True:
...@@ -351,37 +370,54 @@ class MeasureSet: ...@@ -351,37 +370,54 @@ class MeasureSet:
return "Cols: " + str(self.props) + "\n" return "Cols: " + str(self.props) + "\n"
def merge_metadata(metadata, new_metadata, removed_metadata):
metadata.update(new_metadata)
for metadata_name in removed_metadata:
metadata.pop(metadata_name, None)
return metadata
def update_metadata(self, metadata, removed_metadata):
self.metadata = MeasureSet.merge_metadata(self.metadata, metadata, removed_metadata)
def input_metadata(self): def input_metadata(self):
metadata = {} metadata = {}
metadata.update(self.metadata) removed_metadata = []
metadata_name = "" metadata_name = ""
while True: while True:
merged_metadata = MeasureSet.merge_metadata(self.metadata, metadata, removed_metadata)
print("Current metadata:\n") print("Current metadata:\n")
for metadata_name in metadata: for metadata_name in merged_metadata:
print(" {}: {}".format(metadata_name, metadata[metadata_name])) print(" {}: {}".format(metadata_name, merged_metadata[metadata_name]))
metadata_name = input('Enter metadata name (type "done" to exit): ') metadata_name = input('Enter metadata name (type "done" to exit): ')
if metadata_name == "done": if metadata_name == "done":
break break
metadata_value = input('Enter metadata value (type "done" to exit, "cancel" to cancel current metadata): ') metadata_value = input('Enter metadata value (type "done" to exit, "delete" to delete current metadata, "cancel" to cancel current metadata): ')
if metadata_value == "done": if metadata_value == "done":
break break
if metadata_value == "cancel": if metadata_value == "cancel":
continue continue
if metadata_value == "delete":
removed_metadata.append(metadata_name)
continue
metadata[metadata_name] = metadata_value metadata[metadata_name] = metadata_value
return metadata return (metadata, removed_metadata)
def add_metadata(self, measure_type, units, middle, metadata): def add_metadata(self, measure_type, units, middle, metadata, user_input=False):
self.measure_type = measure_type self.measure_type = measure_type
self.units = units self.units = units
self.middle = int(middle) self.middle = int(middle)
self.metadata.update(metadata) self.metadata.update(metadata)
if user_input:
new_metadata, removed_metadata = self.input_metadata()
self.update_metadata(new_metadata, removed_metadata)
def add_chronological(self, props_names, props): def add_chronological(self, props_names, props):
self.props = props self.props = props
...@@ -462,10 +498,6 @@ class MeasureSet: ...@@ -462,10 +498,6 @@ class MeasureSet:
def import_from_json_data(self, data, flat=False, user_input=False): def import_from_json_data(self, data, flat=False, user_input=False):
if user_input:
self.metadata.update(data['metadata'])
data['metadata'] = self.input_metadata()
measure_type = data['measure_type'] measure_type = data['measure_type']
units = data['units'] units = data['units']
metadata = data['metadata'] metadata = data['metadata']
...@@ -474,7 +506,7 @@ class MeasureSet: ...@@ -474,7 +506,7 @@ class MeasureSet:
else: else:
middle = 0 middle = 0
self.add_metadata(measure_type, units, middle, metadata) self.add_metadata(measure_type, units, middle, metadata, user_input)
props_names = data['props_names'] props_names = data['props_names']
...@@ -583,6 +615,7 @@ def parse_args(): ...@@ -583,6 +615,7 @@ def parse_args():
parser.add_argument('--remove', nargs=1, required=False, help='remove a measure') parser.add_argument('--remove', nargs=1, required=False, help='remove a measure')
parser.add_argument('--remove-all', action='store_true', help='remove all measure sets') parser.add_argument('--remove-all', action='store_true', help='remove all measure sets')
parser.add_argument('-m', nargs=1, required=False, help='modify the metadata of a measure') parser.add_argument('-m', nargs=1, required=False, help='modify the metadata of a measure')
parser.add_argument('-M', nargs=1, required=False, help='modify the metadata of all measures of a type')
parser.add_argument('-t', nargs='?', const='input_file', required=False, help='generate table') parser.add_argument('-t', nargs='?', const='input_file', required=False, help='generate table')
parser.add_argument('-R', action='store_true', required=False, help='generate full measure report') parser.add_argument('-R', action='store_true', required=False, help='generate full measure report')
parser.add_argument('-G', action='store_true', required=False, help='generate all graphs') parser.add_argument('-G', action='store_true', required=False, help='generate all graphs')
...@@ -602,6 +635,11 @@ def parse_args(): ...@@ -602,6 +635,11 @@ def parse_args():
mtype, mid = name_to_mtype_mid(args.m[0]) mtype, mid = name_to_mtype_mid(args.m[0])
ms_handler.modify_metadata(mtype, mid) ms_handler.modify_metadata(mtype, mid)
if args.M is not None:
mtype = str(args.M[0])
ms_handler.modify_metadata(mtype)
if args.i is not None: if args.i is not None:
if args.c: if args.c:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment