Compare commits

..

No commits in common. "888e1593f9b88e73a4be63716622737023c4b82a" and "3eea3854dccb47b5da78085c71a39f081bd3a378" have entirely different histories.

3 changed files with 13 additions and 18 deletions

View File

@ -2,26 +2,23 @@
""" """
extracteur de données iSpindel JSON entreposées par Little Bock en HTML extracteur de données iSpindel JSON entreposées par Little Bock en HTML
""" """
import json, pathlib import json
try: try:
import lxml.html as LX import lxml.html as LX
except ModuleNotFoundError: except ModuleNotFoundError:
import sys import sys
sys.exit("Le module 'lxml' est nécessaire.\n\thttp://pypi.org/lxml") sys.exit("Le module 'lxml' est nécessaire.\n\thttp://pypi.org/lxml")
import pathlib
def jsproc(data): def jsproc(data):
"""supprime les données inutiles d'une série""" """nettoie des données récursivement"""
unwanted = ("color","opacity","yAxis","dashStyle", "tooltip",) unwanted = ["color","opacity","yAxis","dashStyle"]
if data.get("data"):
for u in unwanted: for u in unwanted:
if u in data.keys(): if u in data.keys():
if u == "tooltip":
tt = data.get(u)
suffix = tt.get("valueSuffix")
if suffix: data.update({
"name": " ".join([data["name"], suffix])
})
del(data[u]) del(data[u])
for k,v in data.items():
if isinstance(v,dict):
jsproc(v)
return data return data
def hproc(path_in): def hproc(path_in):
@ -32,13 +29,11 @@ def hproc(path_in):
if x: data1 = x[0].get('data-chart-options') if x: data1 = x[0].get('data-chart-options')
if data1: if data1:
for i in json.loads(data1).pop('series'): for i in json.loads(data1).pop('series'):
data = jsproc(i) data2.append(jsproc(i))
if data: data2.append(data)
if len(data2) > 0: if len(data2) > 0:
path_out = path_in.with_suffix('.json') path_out = path_in.with_suffix('.json')
with open(path_out,'w') as f: with open(path_out,'w') as f:
f.write(json.dumps(data2, f.write(json.dumps(data2, indent=2, sort_keys=False))
sort_keys=False, ensure_ascii=False, indent=2))
print(f"INFO: {path_in.name} >> {path_out.name}") print(f"INFO: {path_in.name} >> {path_out.name}")
if __name__ == "__main__": if __name__ == "__main__":