麻烦在pythonanywhere

时间:2015-12-30 16:33:02

标签: python pythonanywhere

我是pythonanywhere的第一次用户

我首先从github通过bash控制台执行我的代码的git克隆。我没有使用虚拟环境。我的app.py文件中调用了我的WSGI应用程序。此外,我的代码使用sqlalchemy与我的数据库进行交互。

基本上,烧瓶应用程序就像一个自定义API,为GET和POST请求返回JSON,我在查看JSON输出时遇到问题。我不确定我到底做错了什么或错过了什么。

app.py文件中的代码:

#!flask/bin/python
from flask import Flask
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy_declarative import Base, Quote
from flask import request
from flask import abort
import json

#connect to database

engine = create_engine("sqlite:///quotes.db")

Base.metadata.bind = engine
DBSession = sessionmaker(bind=engine)
session = DBSession()

app = Flask(__name__)

@app.route("/trumptext/api/quotes", methods=["GET"])
def get_quotes():
    quoteList = session.query(Quote).all()
    result = []
   for q in quoteList:
       my_dict = {}
       my_dict["id"] = q.id
       my_dict["quote"] = q.quote
       result.append(my_dict)
   return json.dumps(result,ensure_ascii=False).encode('utf8')

@app.route("/trumptext/api/quotes", methods=["POST"])
def add_quote():
    if not request.json or not "quote" in request.json:
        abort(400)
    new_quote = request.json["quote"]
    q = Quote(quote=new_quote)
    session.add(q)
    session.commit()
    quoteList = session.query(Quote).all()
    last = quoteList[-1]
    result = []
    my_dict = {}
    my_dict["id"] = last.id
    my_dict["quote"] = last.quote
    result.append(my_dict)
    return json.dumps(result,ensure_ascii=False).encode('utf8'), 201


if __name__ == "__main__":
    app.run()

此外,/ var / www / hdson_pythonanywhere_com_wsgi.py中的代码:

import os
import sys

path = '/home/nnelson/trumptextapi'
if path not in sys.path:
    sys.path.append(path)

from app import app as application

如果我输入的内容如下: http://nnelson.pythonanywhere.com/trumptext/api/quotes(执行GET请求)

理想情况下,它应该以JSON格式返回存储在quotes.db数据库中的所有引号,但是我得到的输出看起来像这样:[]我使用curl工具在localhost上测试了我的代码,它工作得很好。我在托管它时遇到了麻烦

感谢任何帮助。

1 个答案:

答案 0 :(得分:3)

您正在使用数据库的相对路径,因此它可能正在查看您不期望的数据库。使用数据库的完整路径或使其相对于app.py文件的路径,以便您知道它从何处获取数据库。