Как исправить проблему crontab или 'os.execute ()' с помощью скрипта Python? - PullRequest
0 голосов
/ 30 января 2019

Я запускаю domoticz на PI3b с Raspbian, для лучшей эффективности у PI3b теперь есть 7-дюймовый экран, чтобы показать поведение домотики + информацию о метеостанции + интернет-прогноз ... Чтобы показать все это, я написал C ++ /Приложение WXWidget с графикой для температуры / давления ... Графики температуры / давления с графиком Python3 / matplotlib сохраняются в виде 3 файлов PNG. Скрипт Python считывает данные в файлах и строит / сохраняет графики.

Работаетхорошо из терминала .... но нет способа работать с crontab или с "os.execute ()" из событий lua-scripts of domoticz ...

Я подтолкнул все разрешения / доступдля сценариев и файлов png (чтение / запись)

Один сценарий python считывает данные с датчика bme280, crontab 2 минуты, без проблем, работает с терминала, crontab, событий lua ...

Второй сценарий считывает данные, строит графики и отправляет команду http json для обновления устройства в domoticz. Это прекрасно работает с терминала, но не из domoticz (lua os.execute ()) или из crontab.

callвcrontab: sudo / usr / bin / python3 /home/pi/Desktop/graph.py

вызов из сценария domoticz lua: os.execute ('sudo / usr / bin / python3 / home / pi / Desktop /graph.py ')

из терминала, он отлично работает с python, / usr / bin / python или / usr / bin / python3 (-> matplotlib)

python --version =3.7.0

Это похоже на проблему между многими версиями Python, хорошая не вызывается из crontab и lua-scripts .... Как это исправить?

версия Python по умолчаниюдо 2.7.0, 3.0, 3.6, 3.7 проверено, чтобы проверить проблему с env / bin / path ... единственная проблема, обнаруженная с urllib.urlopen, изменена на "urlopen from urllib.request"

#!/usr/bin/python3

import matplotlib.lines as lines
import matplotlib.pyplot as plt
   #import urllib   ---> urllib.urlopen() works with /usr/bin/python
from urllib.request import urlopen   #---> to work with /usr/bin/python3

fig = plt.figure()
ax = fig.add_subplot(111)
ax.grid(which='major', axis='x', color=(0.6, 0.6, 0.6), linewidth=1)
ax.patch.set_color('black')
fig.set_facecolor((0.0, 0.0, 0.0))
fig.set_size_inches(26.25, 7.42)
fig.patch.set_facecolor('black')

ax.spines["top"].set_visible(False)    
ax.spines["bottom"].set_visible(False)    
ax.spines["right"].set_visible(False)    
ax.spines["left"].set_visible(False) 
plt.ylim(0, 63)    
plt.xlim(0, 210) 
plt.style.use('dark_background')
list = []
d1 = 0
d2 = 0
d3 = 0


def readf( str ):     #open/read file, fill the list
    list[:] = []
    with open(str) as infile:         #parsing to float
        numbers = infile.read()
        numbers = numbers.replace(" ","").replace("\r","").replace("\n","")
        for num in numbers.split(";"):
            n = float(num)
            list.append(n)
    infile.close()
    if str == "/home/pi/Dev/PI-Weather_Station/pressval.txt":
        t = len(list) - 1
        t1 = t - 6
        t2 = t - 12
        t3 = t - 24
        d1 = list[t] - list[t1]
        d2 = list[t] - list[t2]
        d3 = list[t] - list[t3]
        if d1 < 0 and d2 < 0:
            httpresponse = urlopen("http://192.168.x.xxx:xxxx/json.htm?type=command&param=updateuservariable&vname=tendance&vtype=2&vvalue=baisse")
        elif d1 < 0 and d2 > 0:
            httpresponse = urlopen("http://192.168.x.xxx:xxxx/json.htm?type=command&param=updateuservariable&vname=tendance&vtype=2&vvalue=stable")
        elif d1 > 0 and d2 > 0:
            httpresponse = urlopen("http://192.168.x.xxx:xxxx/json.htm?type=command&param=updateuservariable&vname=tendance&vtype=2&vvalue=hausse")
        elif d1 > 0 and d2 < 0:
            httpresponse = urlopen("http://192.168.x.xxx:xxxx/json.htm?type=command&param=updateuservariable&vname=tendance&vtype=2&vvalue=stable")
    return;

def chart( stg ):           #plot/save the charts
    o = len(list)
    omin = 1400
    omax = -50
    i = 0
    n = 0
    line = lines.Line2D([i, i+1], [list[i], list[i+1]], lw=1, color='blue', axes=ax)
    if o > 210:
        i = o - 210
        n = i
    while i < o-1:
        if stg == "/home/pi/Dev/PI-Weather_Station/tex.png":
            line = lines.Line2D([i, i+1], [list[i], list[i+1]], lw=3, color=(0.0, 0.7, 1.0), axes=ax)
            ax.add_line(line)
        elif stg == "/home/pi/Dev/PI-Weather_Station/tin.png":
            line = lines.Line2D([i, i+1], [list[i], list[i+1]], lw=3, color='yellow', axes=ax)
            ax.add_line(line)
        elif stg == "/home/pi/Dev/PI-Weather_Station/press.png":
            line = lines.Line2D([i, i+1], [list[i], list[i+1]], lw=3, color='red', axes=ax)
            ax.add_line(line)
        if list[i] < omin:
            omin = list[i]
        if list[i] > omax:
            omax = list[i]
        i += 1
    ax.axis([n, o, omin - 0.1, omax + 0.1])
    ax.axhline((omax+omin)/2, 0, 1)
    ax.axvline(n+30, 0, 1)
    ax.axvline(n+60, 0, 1)
    ax.axvline(n+90, 0, 1)
    ax.axvline(n+120, 0, 1)
    ax.axvline(n+150, 0, 1)
    ax.axvline(n+180, 0, 1)
    fig.savefig(stg, dpi = 10, bbox_inches = 'tight')    
    return;

readf("/home/pi/Dev/PI-Weather_Station/texval.txt")
chart("/home/pi/Dev/PI-Weather_Station/tex.png")
readf("/home/pi/Dev/PI-Weather_Station/tinval.txt")
chart("/home/pi/Dev/PI-Weather_Station/tin.png")
readf("/home/pi/Dev/PI-Weather_Station/pressval.txt")
chart("/home/pi/Dev/PI-Weather_Station/press.png")
plt.close()

1 Ответ

0 голосов
/ 30 января 2019

Oky,

source: Генерация PNG с matplotlib, когда DISPLAY не определена

, который был pb с matplotlib, скрипт отлично работает в терминале, но для другихему нужно больше кодов:

#!/usr/bin/python

import matplotlib
matplotlib.use('Agg')
...