в продолжение моего предыдущего вопроса: найди ответ
у меня исправлен код hmtl, и он здесь:
<!DOCTYPE html>
<html lang = "en">
<head>
<meta charset = "UTF-8">
<title>Select image</title>
</head>
<body>
<form action = "{{ url_for('image_shape')}}"method = "post">
<label for = "img">Select image</label>
<input type = "file" id = "img" name = "img" accept = "image/*" onchange = "displayImage(this)">
<br>
<img id = "selectedImg" src = "#" alt = "Selected Image" style = "display:none; max-width: 300px;">
<br>
<input type = "submit">
</form>
<script>
function displayImage(input) {
var file = input.files[0];
var reader = new FileReader();
reader.onload = function(e) {
var imgElement = document.getElementById('selectedImg');
imgElement.src = e.target.result;
imgElement.style.display = 'block';
};
reader.readAsDataURL(file);
}
</script>
<h4 style = "color:Violet;">
{{ prediction_text }} </h4>
</body>
</html>
но сейчас я хочу следующее: когда пользователь загружает изображение, я хочу извлечь имя этого изображения и прочитать его в Python с помощью opencv, для этого я написал следующий код (сейчас opencv еще нет)
from flask import Flask, request,render_template
from bs4 import BeautifulSoup
import re
app =Flask(__name__)
@app.route('/')
def image_shape():
code =[x for x in request.form.values()]
text= f'i have {code}'
return render_template("Select_IMage.html",prediction_text=text)
if __name__= = "__main__":
app.run(debug=True)
когда я бегу, я получаю следующую часть:
идея в том, что выбор изображения работает нормально, но эта строка:
code =[x for x in request.form.values()]
ничего не возвращает, я уже пробовал несколько экспериментов со значениями формы, возможно, здесь выбор изображения не соответствует форме, и как я могу вернуть имя изображения, которое отображается рядом с кнопкой выбора? заранее спасибо
Для загрузки изображения необходима форма типа multipart/form-data
, которую можно указать с помощью атрибута enctype.
<form enctype = "multipart/form-data">
<!-- ... -->
</form>
Загруженные файлы можно запросить во Flask из диктофона request.files
. Вы получите объект типа FileStorage, из которого вы можете получить имя файла и сохранить его в подходящем месте, а затем открыть его с помощью opencv.
Подробную инструкцию по загрузке файлов вы можете найти здесь.
Прежде всего, когда вы отправляете форму типа POST, вы должны принять этот тип запроса в маршруте. Затем внутри вашей конечной точки вы можете использовать request.method
, чтобы определить, является ли это запросом POST или GET.
Данные формы можно запросить с помощью атрибута имени поля ввода. В отличие от значений полей обычной формы, файлы, как описано, хранятся не в request.form
, а в request.files
.
Полученный объект FileStorage помимо прочих атрибутов содержит имя файла.
from flask import (
Flask,
render_template,
request
)
app = Flask(__name__)
@app.route('/', methods=['GET','POST'])
def image_shape():
text = 'Please select and upload a file.'
if request.method == 'POST':
file = request.files.get('img')
if file and file.filename != '':
text=f'I have {file.filename}'
return render_template('Select_IMage.html', prediction_text=text)
if __name__= = "__main__":
app.run(debug=True)
спасибо большое, но способ загрузки не работает и как это сделать?
Что вы подразумеваете под «не работает»? Следовали ли вы руководству по загрузке файлов и использовали правильный enctype и dict?
не могли бы вы увидеть мое обновленное решение?
Я действительно заблудился, так мне не нужен html-файл? как я могу отобразить имя файла в html?
Я обновил свой ответ. В будущем, пожалуйста, обновите свой вопрос вместо того, чтобы публиковать вопрос в качестве ответа.
я удалил свое решение, кстати, можно ли напечатать имя файла на консоли? потому что <input type = "submit"> не работает
также этот request.files.get('img') не возвращает ничего
Отвечает ли это на ваш вопрос? При загрузке файлов HTML-формы не загружается файл