dominic revised this gist . Go to revision
1 file changed, 101 insertions
dmrids-gd77.py(file created)
@@ -0,0 +1,101 @@ | |||
1 | + | #!/usr/bin/env python3 | |
2 | + | ||
3 | + | """Fetches the DMRID database from radioid.net | |
4 | + | ||
5 | + | This script fetches the database of DMRIDs directly from | |
6 | + | radioid.net and creates a CSV file to import it into | |
7 | + | the GD77 running OpenGD77. | |
8 | + | ||
9 | + | Author: Dominic Reich “OE7DRT” | |
10 | + | <quick.hat4396@qtztsjosmprqmgtunjyf.com> | |
11 | + | ||
12 | + | ||
13 | + | Usage: | |
14 | + | ------ | |
15 | + | ./dmrids.py | |
16 | + | ||
17 | + | No arguments are needed. Specify the folders in the | |
18 | + | source below. | |
19 | + | """ | |
20 | + | ||
21 | + | import os | |
22 | + | from datetime import datetime, timedelta | |
23 | + | import requests | |
24 | + | import pandas as pd | |
25 | + | ||
26 | + | ||
27 | + | def main(): | |
28 | + | """main function | |
29 | + | ||
30 | + | Runs if script is run by itself. | |
31 | + | """ | |
32 | + | ||
33 | + | # User configuration -------------------------------- | |
34 | + | database_url = 'https://www.radioid.net/static/user.csv' | |
35 | + | local_folder = '/home/dominic/.hamradio/' | |
36 | + | output_filename = 'DMR-IDS-GD77.csv' | |
37 | + | tmpfile = '/tmp/dmrids.download' | |
38 | + | regions = ['232', '262', '263', '264', '228', '222'] | |
39 | + | # regions = ['232'] | |
40 | + | fav_filename = 'Favorites.txt' | |
41 | + | # blacklist_filename = 'BlacklistedCalls.txt' | |
42 | + | ||
43 | + | # End of User configuration ------------------------- | |
44 | + | ||
45 | + | if os.path.isfile(local_folder + output_filename) and os.access(local_folder + output_filename, os.R_OK): | |
46 | + | print('Local file found. Will overwrite the file if it\'s old enough.') | |
47 | + | one_day_ago = datetime.now() - timedelta(days=1) | |
48 | + | filetime = datetime.fromtimestamp( | |
49 | + | os.path.getctime(local_folder + output_filename)) | |
50 | + | if not filetime < one_day_ago: | |
51 | + | print('Nope, the file is quite actual ({})\n'.format(filetime)) | |
52 | + | a = input( | |
53 | + | 'Do you really want to fetch the database? (y/n): ') | |
54 | + | if a.lower() != 'y': | |
55 | + | exit(0) | |
56 | + | ||
57 | + | # read favorites | |
58 | + | favorites = [] | |
59 | + | if os.path.isfile(local_folder + fav_filename) and os.access(local_folder + fav_filename, os.R_OK): | |
60 | + | with open(local_folder + fav_filename, 'r') as file: | |
61 | + | for line in file: | |
62 | + | line = line.strip() | |
63 | + | favorites.append(line) | |
64 | + | else: | |
65 | + | # This is because the program will create weird resuls otherwise. | |
66 | + | # Needs some error handling but is not finished yet. So there we use this | |
67 | + | # now until fixed. | |
68 | + | print('Could not open favorites file.') | |
69 | + | exit(1) | |
70 | + | ||
71 | + | print('Downloading database (this may take some time)') | |
72 | + | r = requests.get(database_url) | |
73 | + | if r.status_code == 200: | |
74 | + | with open(tmpfile, "wb") as file: | |
75 | + | file.write(r.content) | |
76 | + | else: | |
77 | + | print('Download failed. Exiting') | |
78 | + | exit(1) | |
79 | + | ||
80 | + | # Damn this took so long to figure out that I have to escape them with \\ | |
81 | + | # and not only with \ ... *grml* | |
82 | + | searchstr = '\\b(?:' + '|'.join(regions) + ')\\d+\\b' | |
83 | + | favsearchstr = '|'.join(favorites) | |
84 | + | ||
85 | + | # Open full csv file and create two DataFrames with filtered users and favorites | |
86 | + | csv_full = pd.read_csv(tmpfile, dtype=str, usecols=['RADIO_ID', 'CALLSIGN', 'FIRST_NAME']) | |
87 | + | csv_filt = csv_full[csv_full['RADIO_ID'].str.contains(searchstr)] | |
88 | + | csv_favs = csv_full[csv_full['CALLSIGN'].str.contains(favsearchstr, na=False)] | |
89 | + | ||
90 | + | # Merge regional and whitelist, sort and remove dupes | |
91 | + | csv_fin = pd.concat([csv_filt, csv_favs], ignore_index=True) | |
92 | + | csv_fin.sort_values('RADIO_ID', inplace=True) | |
93 | + | csv_fin.drop_duplicates(subset=['RADIO_ID'], inplace=True) | |
94 | + | ||
95 | + | # Write the final csv file | |
96 | + | csv_fin.to_csv(local_folder + output_filename, index=False) | |
97 | + | # print(csv_fin[csv_fin['CALLSIGN'].isin(['DD7MH'])]) | |
98 | + | ||
99 | + | ||
100 | + | if __name__ == "__main__": | |
101 | + | main() |
Newer
Older