This repository has been archived by the owner on Sep 3, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathocean_data.py
executable file
·78 lines (62 loc) · 2.75 KB
/
ocean_data.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
72
73
74
75
76
77
78
#!/usr/bin/python3 -tt
import os
from configparser import ConfigParser, ExtendedInterpolation
from ocean_modules.noaa_parser import NoaaParser
from ocean_modules.send_text import _tsend as send_text
def make_message(input_data):
'''Returns a string from input_data after testing whether input is list
or dict. Dict will actually be a nested dict (see noaa_parser.py)'''
messagestring = ''
if isinstance(input_data, list):
messagestring = '\n'.join(input_data)
elif isinstance(input_data, dict):
for key, val in input_data.items():
messagestring += key + '\n'
if isinstance(val, dict):
for newkey, newval in val.items():
messagestring += newkey + ' ' + newval + '\n'
else:
messagestring += val + '\n'
return messagestring
# def receive_requests(username, password, server):
# Ideally, this will be the part that watches for changes...
# It will go somewhere else...
# new_mails = check_mail.receive_email(username, password, server)
# senders_requests = check_mail.email_parsing_from_SMS(new_mails)
# return senders_requests
def read_config():
parser = ConfigParser(interpolation=ExtendedInterpolation())
script_dir = os.path.dirname(os.path.realpath(__file__))
conf_file = os.path.join(script_dir, 'config', 'config')
parser.read(conf_file)
return parser
if __name__=='__main__':
configs = read_config()
# Email configs: server allows checking of address if set-up
email_server = configs['email']['server']
username = configs['email']['username']
password = configs['email']['password']
recipient = configs['cell settings']['recipient']
# Location settings
source = configs['noaa.gov settings']['my_source']
location = configs['noaa.gov settings']['location']
time_zone = configs['location settings']['set_time_zone']
all_dat = configs['forecast settings'].getboolean('send_all_data')
forecast = configs['forecast settings'].getboolean('send_marine_forecast')
hours_ = int(configs['forecast settings']['hours_ahead_to_forecast'])
tmpfile = 'tmp-forecast.csv'
weather = NoaaParser()
weather.get_locations(location, source)
if all_dat:
message = weather.weather_get_all() # returns a list
else:
message = weather.weather_info_dict(time_zone) # returns a dict
if forecast:
with open(tmpfile, 'w') as f:
for n in weather.prettify_forecast(hours_ahead=hours_):
field, time, data = n
f.write(field + ',' + time + ',' + data + '\n')
else:
pass
weather_msg = location + '\n' + make_message(message)
send_text(username, password, recipient, weather_msg) # need attachment module