Сценарий 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
]
}
]
}
})