-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfind_calls.py
71 lines (58 loc) · 2.23 KB
/
find_calls.py
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
63
64
65
66
67
68
69
70
71
#!/usr/bin/env python
import csv
################################################################################
def chars(first, last):
res = []
for c in range(ord(first),ord(last)+1):
res.append( chr(c) )
return res
def alphabet():
return chars('A','Z')
def numbers():
return chars('0','9')
def two_by_one(remove_11_13=True):
res = []
for a in ['A','K','N','W']:
for b in alphabet():
for c in numbers():
for d in alphabet():
if (a == 'A') and (ord(b) >= ord('M')):
# Any call sign having the letters AM-AZ as the prefix
# is assigned to other countries by the ITU.
continue
if (a+b in ['KP', 'NP', 'WP']) and (int(c) in [0, 6, 7, 8, 9]):
# Any 2-by-1 format call sign having the letters KP, NP
# or WP as the prefix and the numeral 0, 6, 7, 8 or 9
# is not available for assignment.
continue
if remove_11_13 and (a+b in ['AL', 'KL', 'NL', 'WL', 'KP', 'NP', 'WP', 'AH', 'KH', 'NH', 'WH']):
# Two letter prefixes that are designated for regions
# 11-13 are not available in regions 1-10.
continue
res.append( a+b+c+d )
return res
def one_by_two():
res = []
for a in ['K','N','W']:
for b in numbers():
for c in alphabet():
for d in alphabet():
#print a+b+c+d
res.append( a+b+c+d )
return res
################################################################################
db = './l_amat/HD.dat'
possibilities = one_by_two() + two_by_one()
in_use = []
with open(db) as csvfile:
csvreader = csv.reader(csvfile, delimiter='|')
for row in csvreader:
if row[5] == 'A': # Active, not Cancelled Expired or Terminated
if len(row[4]) == 4: # only care about 2x1 and 1x2
in_use.append(row[4])
remaining = []
for callsign in possibilities:
if callsign not in in_use:
remaining.append( callsign )
print remaining
print len(remaining)