【问题标题】:Getting a requested URL not found error when running flask code运行烧瓶代码时出现未找到请求的 URL 错误
【发布时间】:2019-05-01 23:27:36
【问题描述】:

创建了一个网络应用程序,并设法构建了一个函数来清理来自 Google 我的业务导出的 csv 文件。但是,当我使用我编写的代码运行该函数时,我收到以下错误消息:

找不到

在服务器上找不到请求的 URL。如果您输入了 URL 请手动检查您的拼写,然后重试。

不知道哪里出错了

mport os
import pandas as pd
from flask import Flask, request, redirect, url_for
from flask import Flask, make_response
from werkzeug.utils import secure_filename

UPLOAD_FOLDER = './Downloads/gmbreports'
if not os.path.exists(UPLOAD_FOLDER):
    os.makedirs(UPLOAD_FOLDER)

ALLOWED_EXTENSIONS = 'csv'

app = Flask(__name__)
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
def allowed_file(filename):
    return '.' in filename and \
           filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS

def transform(text_file_contents):
    disc = open('clean.csv')
    disc2 = open('clean_two.csv','w')
    #cleaning up csv
    for row in disc:
        row = row.strip()
        row = row[1:-1]
        row = row.replace('""','"')
        disc2.write(row+'\n')
    disc2.close()
    disc.close()
    discovery = pd.read_csv('clean_two.csv')
    discovery_clean = discovery.iloc[1:]
    cols = list(discovery_clean.columns[4:])
    discovery_clean[cols] = discovery_clean[cols].apply(pd.to_numeric,errors='coerce')
    return discovery_clean

@app.route('/', methods=['GET', 'POST'])
def upload_file():
    if request.method == 'POST':
        if 'file' not in request.files:
            flash('No file part')
            return redirect(request.url)
        file = request.files['file']
        if file.filename == '':
            flash('You need to upload a csv file')
            return redirect(request.url)
        if file and allowed_file(file.filename):
            filename = secure_filename(file.filename)
            file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename))
            return redirect(url_for('uploaded_file',
                                    filename=filename))
    return '''
    <!doctype html>
    <title>Google My Business Discovery Report Builder</title>
    <h1>Upload GMB Discovery csv</h1>
    <form action="\transform" method="post" enctype="multipart/form-data">
      <p><input type="file" name="file">
         <input type="submit" value=Upload>
    </form>
    '''
@app.route('/transform',methods=["POST"])
def transform_view():
    request_file=request.files['file']
    request_file.save('clean.csv')
    if not request_file:
        return "No file"
    result = transform()
    print(result)

    response = make_response(result)
    response.headers["Content-Disposition"] ="attachment; filename=result.csv"
    return response


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

注意:我在运行脚本并上传 csv 后收到此错误消息。期望的结果是上传一个 csv,并将其作为清理后的数据表显示在我的屏幕上

【问题讨论】:

  • 您在运行烧瓶服务器的终端中收到什么错误消息?
  • @mousahalaseh 不确定您的意思,如果我运行脚本并尝试上传 csv,我会收到 Not Found 错误
  • 另外,直接从您的方法呈现 HTML 是一个糟糕的设计。使用单独的模板引擎(例如Jinja
  • 您是如何运行应用程序的?
  • @mousahalaseh python main.py on bash 然后我得到一个允许我上传 csv 文件的页面,我上传文件并收到此错误消息

标签: python flask


【解决方案1】:

这里有多个问题。首先,Wondercricket 关于表单动作是正确的。它需要更改为“/transform”。

完成后,您仍然会收到内部服务器错误。在这种情况下,您的 transform 函数被定义为采用单个参数,但不会使用一个参数来调用它。简单地改变

def transform(text_file_contents):

def transform():

这应该允许上传发生,并且转换现在将运行。但是,还有最后一个问题。 transform 返回一个 pandas DataFrame,Flask 不能将其用作响应。改变

response = make_response(result)

response = make_response(result.to_csv())

你应该很高兴。

【讨论】:

  • 另外,请记住,如果您只是通过python main.py 运行它,那么您需要在进行更改后重新启动服务器。
猜你喜欢
  • 2020-07-09
  • 1970-01-01
  • 1970-01-01
  • 2017-06-02
  • 2018-05-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-07-13
相关资源
最近更新 更多