Сценарий Python для публикации данных на geckoboard

Я ищу помощь в создании сценария Python, который будет выдвигать данные, в частности, на geckoboard в виде линейного графика. В настоящее время приведенный ниже код, собранный из других источников, было бы замечательно, если бы кто-то мог сотрудничать и помочь мне закончить это, я не знаю, как вставить нужные значения в линейный график, если это может быть закончен с некоторыми примерами значений, которые были бы хорошими. Спасибо

import requests
import json

class Gecko(object):
def __init__(self, api_key):
    self.api_key = api_key

def push(self, widget_key, data):
    ret = requests.post("https://push.geckoboard.com/v1/send/%s" % widget_key, json.dumps({'api_key' : self.api_key, 'data' : data}), verify=False)
    if not (ret.status_code == 200 and ret.json().get('success') == True):
        raise ValueError(ret.content)

def line(self, widget_key, values, **kwargs):
    data = {'item' : [], 'settings' :kwargs}
    for item in values:
        data['item'].append(item)
    return self.push(widget_key, data)

run=Gecko(****************)
print run.push(150634-85f8db34-af52-4fa3-9963-3200a9a6fe74,some_data?)
print run.line(150634-85f8db34-af52-4fa3-9963-3200a9a6fe74,100,'text')

2 ответа

Изменить: Таким образом, самая большая проблема, кажется, формирование вашей полезной нагрузки JSON. Согласно документации Geckoboard API, она должна выглядеть следующим образом:

{"api_key" : "some-api-key-goes-here",
 "data": {
     "y_axis": {
         "format": "currency",
        "unit": "USD"
      },
      "series": [
        {
          "name": "GBP -> USD",
          "data": [
            1.62529,
            1.56991,
            1.50420,
            1.52265,
            1.55356,
            1.51930,
            1.52148,
            1.51173,
            1.55170,
            1.61966,
            1.59255,
            1.63762
          ]
        }
      ]
    }
 }

Во время вызова API вы в основном собираете полезную нагрузку JSON, а затем отправляете ее по адресу с ключом. Ключ-виджет - это уникальный адрес или URL-адрес, по которому geckoboard хочет, чтобы вы публиковали сообщения, ключ api_key - это ключ вашей учетной записи. Поток, в котором вы хотите, чтобы ваша программа работала, выглядит следующим образом: 1) Соберите ваши данные 2) Соберите ваши данные в JSON-подобную структуру (словари и списки вложены) 3) Создайте дамп JSON (Это означает преобразование вашей специфичной для Python структуры в JSON состав). 4) Разместите этот JSON на конкретном сервере.

Вот ваш обновленный код:

import requests
import json

class Gecko(object):
    def __init__(self, widget_key, api_key):

        # You put the widget and api_key values here so you can set it once you
        # call your object and set it.
        self.api_key = api_key
        self.widget_key = widget_key
        self.payload = {
            'api_key' : self.api_key,
            'data' : None
        }

    def push(self):
        ret = requests.post(
            "https://push.geckoboard.com/v1/send/%s" % self.widget_key,
            json.dumps(self.payload),
            verify=False
        )
        if not (ret.status_code == 200 and ret.json().get('success') == True):
            raise ValueError(ret.content)

    # This function is the batteries included version.  It takes all allowable
    # values and checks if they have been provided.  If so, it'll post.
    def line(self, name, data_list, x_axis_labels=None,
             x_axis_type=None, y_axis_format=None, y_axis_unit=None):

        _data = {"series": [{"name": name,
                            "data": data_list}]}

        # Add x_axis to _data if there is an additional param.
        if x_axis_labels is not None or x_axis_type is not None:
            _data["x_axis"] = None

        if x_axis_labels is not None:
            _data["x_axis"]["labels"] = x_axis_labels

        if x_axis_type is not None:
            _data["x_axis"]["type"] = x_axis_type

        # Add y_axis to _data if there are y_axis params.
        if y_axis_format is not None or y_axis_unit is not None:
            _data['y_axis'] = None

        if y_axis_format is not None:
            _data["y_axis"]["format"] = y_axis_format

        if y_axis_unit is not None:
            _data["y_axis"]["unit"] = y_axis_unit

        self.payload["data"] = _data


# Usage:
# Step 1: Form your object and assign it to a variable.  The class now requires
# widget_key and API key to start off with.
line_widget = Gecko(
    widget_key="12345-12315-asfdasdf-asdfasfd",
    api_key="1234-1234-1234-1234")

# Step 2: Add data to the payload:
line_widget.line(name="Something Line graph",
                 data_list=[1,2,3,4,5,6,7],
                 x_axis_labels=["one", "two", "three", "four", "five", "six", "seven"])

# Step 3: Push the data
line_widget.push()

Извините, я не могу проверить, работает ли код прямо сейчас, но я вполне уверен, что это 95% пути. Если вы ищете более простой способ, я создал библиотеку, которая обрабатывает формирование JSON и передает данные в пользовательские виджеты на geckoboard.

Вы можете проверить Геккопуш и сообщить мне, если у вас есть какие-либо вопросы. Сейчас он находится в несколько стабильной версии, и я активно работаю над этим.

РЕШЕНИЕ:

Файл с именем test.py

import requests
import json

class Gecko(object):
def __init__(self, api_key):
    self.api_key = api_key

def push(self,data):
    ret = requests.post("paste URL here", data=json.dumps(data), verify=False)
    if not (ret.status_code == 200 and ret.json().get('success') == True):
        raise ValueError(ret.content)

Файл с именем test1.py

 from test import Gecko
 gecko=Gecko("*************")
 gecko.push({
"api_key": "**************", 
"data": {   
"x_axis": {
        "labels": ["Week 1", "Week 2", "Week 3", "Week 4"]
    },
    "series": [
        {
            "data": [
                10000, 13500, 21000, 1900
            ]
        }
    ]
}
})
Другие вопросы по тегам