forked from dancergraham/HeadFirstDesignPatterns_python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathweather.py
71 lines (51 loc) · 1.9 KB
/
weather.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
class Subject:
def register_observer():
raise NotImplementedError
def remove_observer():
raise NotImplementedError
def notify_observers():
raise NotImplementedError
class Observer:
def update():
raise NotImplementedError
class DisplayElement:
def display():
raise NotImplementedError
class WeatherData(Subject):
def __init__(self):
self._observers = []
def register_observer(self, observer: Observer):
self._observers.append(observer)
def remove_observer(self, observer: Observer):
self._observers.remove(observer)
def notify_observers(self):
for observer in self._observers:
observer.update(self._temperature, self._humidity, self._pressure)
def set_measurements(self, temperature: float, humidity: float, pressure: float):
self._temperature = temperature
self._humidity = humidity
self._pressure = pressure
self.notify_observers()
class CurrentConditionsDisplay(DisplayElement, Observer):
def __init__(self, weather_data):
self._temperature = None
self._humidity = None
self._weather_data = weather_data
weather_data.register_observer(self)
def display(self):
print(
f"Current conditions: {self._temperature:.1f}F degrees and {self._humidity:.1f}% humidity"
)
def update(self, temperature: float, humidity: float, pressure: float):
self._temperature = temperature
self._humidity = humidity
self.display()
def weather_station():
weather_data = WeatherData()
current_display = CurrentConditionsDisplay(weather_data)
# statistics_display = StatisticsDisplay(weather_data)
weather_data.set_measurements(80, 65, 30.4)
weather_data.set_measurements(82, 70, 29.2)
weather_data.set_measurements(78, 90, 29.2)
if __name__ == "__main__":
weather_station()