CMS 3D CMS Logo

das-selected-lumis.py
Go to the documentation of this file.
1 #!/bin/env python
2 from __future__ import print_function
3 import json , sys
4 input_range = []
5 output_files_list = []
6 lumi_ranges = sys.argv[1].split(':')
7 for lumi_range in lumi_ranges:
8  input_range.append(tuple(lumi_range.split(',')))
9 
10 jdata = sys.stdin.read()
11 try:
12  lumi_data = json.loads(jdata)
13 except:
14  print(jdata)
15  exit (1)
16 lumi_data = lumi_data['data']
17 
18 def match_in(sub_list,lumi_list):
19  for i in range(int(sub_list[0]),int(sub_list[1])+1):
20  if i >= int(lumi_list[0]) and i <= int(lumi_list[1]): return True
21  return False
22 
23 def check_lumi_ranges(given_lumi_list , sub_range):
24  for lumi_r in given_lumi_list:
25  if match_in(sub_range, lumi_r):
26  return True
27  return False
28 
29 def process_lumi(data):
30  for lumi_info in data:
31  if isinstance(lumi_info['lumi'], list):
32  lumi_nums = lumi_info['lumi'][0]['number']
33  lumi_file = lumi_info['file'][0]['name']
34  else:
35  lumi_nums = lumi_info['lumi']['number']
36  lumi_file = lumi_info['file']['name']
37  if not isinstance(lumi_nums[0], list): lumi_rang = [ [n,n] for n in lumi_nums ]
38  else: lumi_rang = lumi_nums
39  for sub_list in lumi_rang:
40  if check_lumi_ranges(input_range,tuple(sub_list)):
41  output_files_list.append(lumi_file)
42  break
43  for out_file_name in output_files_list:
44  print(out_file_name)
45 
46 #Get file names for desired lumi ranges
47 process_lumi(lumi_data)
48 
std::vector< std::string_view > split(std::string_view, const char *)
def check_lumi_ranges(given_lumi_list, sub_range)
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:66
def match_in(sub_list, lumi_list)