Добавлен touch-файл для мониторинга степени живости, добавлены опции для протоколиров...
[weathermon.git] / filter_meteo.py
old mode 100644 (file)
new mode 100755 (executable)
index b20dc41..fc497db
@@ -35,6 +35,10 @@ def Yesterday():
   dt = Today()
   return dt - datetime.timedelta(days=1)
 
+def Prehistoric():
+  dt = datetime.date(2000,01,01)
+  return dt
+
 def GetData(sid,pid,fromDate=Yesterday(),toDate=Today()):
   if database:
     c = database.cursor()
@@ -48,7 +52,6 @@ def FixRecord(id,value):
   if database:
     c = database.cursor()
     command="UPDATE sensor_values  SET value={} WHERE id='{}'".format(value,id)
-    print command
     c.execute(command)
   else:
     print "No connection to DB"
@@ -56,10 +59,16 @@ def FixRecord(id,value):
 
 def ProcessTable(sid,pid):
 
-  if not current:
+  if process_all:
+    data=GetData(sid,pid,Prehistoric(),Today())
+  elif not current:
     data=GetData(sid,pid)
   else:
     data=GetData(sid,pid,Today(),Tomorrow())  
+
+  if not data:
+    return
+
   sID=[]
   sTime=[]
   sValue=[]
@@ -75,8 +84,6 @@ def ProcessTable(sid,pid):
   
   avg=np.mean(sValueDiff)
 
-  print "Average="+str(avg)
-
   for i in range(0,len(sTime)-1):
     if sValueDiff[i]>avg*filterThreshold:
       print "fixing %s : %5.2f %5.2f %5.2f" % (sTime[i],sValue[i],sValueFilt[i],sValueDiff[i])
@@ -89,6 +96,10 @@ if len(sys.argv)==2 and sys.argv[1]=='current':
 else:
   current=False
 
+if len(sys.argv)==2 and sys.argv[1]=='all':
+  process_all=True
+else:
+  process_all=False
 
 try: