Próbowałem przykład dostarczone przez oficjalnego poradnika znaleźć tutaj:zaopatrujące zmienne do klasy dynamicznie
http://saratoga.readthedocs.org/en/latest/serviceclasses.html
Zrobiłem kilka zmian w kodzie i tak to wygląda:
http://23.21.167.60:8094/v1/yearlength?name=earth
Mój problem polega na tym, że muszę podać konto = 211829 w adresie URL podobnie jak nazwa = ziemia.
To, co napisałem poniżej, działa, ponieważ dostarczyłem numer konta do klasy. Jak zrobić to dynamicznie?
import json
from saratoga.api import SaratogaAPI, DefaultServiceClass
class PlanetServiceClass(DefaultServiceClass):
def __init__(self, myaccount):
self.yearLength = {
"earth": self.myquery(myaccount),
"pluto": {"seconds": 7816176000}
}
def myquery(self, myaccount):
import pandas as pd
query = ('select * from mydata198 where account = %s ') % (myaccount)
import sqlalchemy
engine = sqlalchemy.create_engine('mysql+pymysql://dba:[email protected]/test')
conn = engine.raw_connection()
df=pd.read_sql(query, conn)
return df.to_json()
class PlanetAPI(object):
class v1(object):
def yearlength_GET(self, request, params):
planetName = params["params"]["name"].lower()
return self.yearLength.get(planetName)
APIDescription = json.load(open("planets.json"))
myAPI = SaratogaAPI(PlanetAPI, APIDescription, serviceClass=PlanetServiceClass('211829'))
myAPI.run(port=8094)
Jak mogę przekazać account_num
zmienną z PlanetAPI
klasę do PlanetServiceClass
?
i powinien zmienić myAPI do tego? serviceClass = PlanetServiceClass (account_num) – shantanuo
ok zaktualizował odpowiedź. Musisz przypisać 'account_num' w czasie" request ", a nie czasie inicjalizacji serwera. –
Dzięki. Zadziałało. Ale działa tylko wtedy, gdy skopiuję funkcję myquery w obu klasach. Czemu? – shantanuo