add offline fetching currencies data from local rss file
This commit is contained in:
parent
23df5ca639
commit
5b5f4dbc70
|
@ -28,6 +28,11 @@ def parse_rss(urlsocket):
|
||||||
return(rss_tree)
|
return(rss_tree)
|
||||||
|
|
||||||
|
|
||||||
|
def pass_local_file():
|
||||||
|
rss_tree = ET.ElementTree(file='rss')
|
||||||
|
return(rss_tree)
|
||||||
|
|
||||||
|
|
||||||
def get_exchange_rate(rss_tree, ns):
|
def get_exchange_rate(rss_tree, ns):
|
||||||
# Pathvariables to XML Namespaces with
|
# Pathvariables to XML Namespaces with
|
||||||
rate_path = 'cb:statistics/cb:exchangeRate/'
|
rate_path = 'cb:statistics/cb:exchangeRate/'
|
||||||
|
|
|
@ -29,6 +29,8 @@ def currencies(request):
|
||||||
prepares a view all dynamicaly.
|
prepares a view all dynamicaly.
|
||||||
It can grow in terms of more Currencies over time automaticaly."""
|
It can grow in terms of more Currencies over time automaticaly."""
|
||||||
|
|
||||||
|
message_offline = ''
|
||||||
|
|
||||||
# Namespaces
|
# Namespaces
|
||||||
ns = {'rdf': 'http://www.w3.org/1999/02/22-rdf-syntax-ns#',
|
ns = {'rdf': 'http://www.w3.org/1999/02/22-rdf-syntax-ns#',
|
||||||
'none': 'http://purl.org/rss/1.0/',
|
'none': 'http://purl.org/rss/1.0/',
|
||||||
|
@ -49,7 +51,19 @@ def currencies(request):
|
||||||
raw_data = exchange_rates.get_exchange_rate(rss_tree, ns)
|
raw_data = exchange_rates.get_exchange_rate(rss_tree, ns)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print('currencies/views.currencies() get_exchange_rate() error:', e)
|
print('currencies/views.currencies() get_exchange_rate() error:', e)
|
||||||
raw_data = None
|
# because url seams to be not avalable we fetch a local file in root
|
||||||
|
# didgeridoo/rss to get some older currencies.
|
||||||
|
rss_tree = exchange_rates.pass_local_file()
|
||||||
|
message_offline = """
|
||||||
|
Are you offline? - useing stored currencies.
|
||||||
|
This does not efect you, but your purchase prices will be
|
||||||
|
recalculated as soon as you submit your Order.
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
raw_data = exchange_rates.get_exchange_rate(rss_tree, ns)
|
||||||
|
except Exception as e:
|
||||||
|
print("""currencies/views.currencies()
|
||||||
|
get_exchange_rate.pass_local_file() error:""", e)
|
||||||
today = datetime.now().strftime("%Y-%m-%d")
|
today = datetime.now().strftime("%Y-%m-%d")
|
||||||
|
|
||||||
message_no = "Already querried: "
|
message_no = "Already querried: "
|
||||||
|
@ -141,11 +155,11 @@ def currencies(request):
|
||||||
# here we evaluate what kind of message is valid:
|
# here we evaluate what kind of message is valid:
|
||||||
if len(message_no) > length_of_message_no\
|
if len(message_no) > length_of_message_no\
|
||||||
and len(message_yes) > length_of_message_yes:
|
and len(message_yes) > length_of_message_yes:
|
||||||
message = message_no + message_yes
|
message = message_offline + message_no + message_yes
|
||||||
elif len(message_no) > 24:
|
elif len(message_no) > 24:
|
||||||
message = message_no
|
message = message_offline + message_no
|
||||||
elif len(message_yes) > 18:
|
elif len(message_yes) > 18:
|
||||||
message = message_yes
|
message = message_offline + message_yes
|
||||||
elif datetime.datetime.today().isoweekday() == 6:
|
elif datetime.datetime.today().isoweekday() == 6:
|
||||||
message = """Die Abfrage wurde ohne ergebniss beendet.
|
message = """Die Abfrage wurde ohne ergebniss beendet.
|
||||||
Es ist Samstag, die SNB publiziert nur an Arbeitstagen
|
Es ist Samstag, die SNB publiziert nur an Arbeitstagen
|
||||||
|
|
Loading…
Reference in New Issue