前提・実現したいこと
Python Flaskを使って、
ウェブアプリを作り、
検索結果のログを見ようとしています。
ログの表示方法は、
1.フォームデータ (form data)
2.リモートアドレス (remote address)
3.ユーザーエージェント (user agent)
4.結果 (results)
の4つの分かれる予定です。
■■機能を実装中に以下のエラーメッセージが発生しました。
ログを閲覧する機能がうまく動きません。
特にエラーは起きていないのですが、
出したい
1.フォームデータ (form data)
2.リモートアドレス (remote address)
3.ユーザーエージェント (user agent)
4.結果 (results)
の4つが表示されず、
得たい結果となっていません。
下が現在の状況です。
該当のソースコードPython
コード
from flask import Flask, render_template, request, escape from vsearch import search4letters app = Flask(__name__) def log_request(req: 'flask_request', res: str) -> None: with open('vsearch.log', 'a')as log: print(req.form, req.remote_addr, req.user_agent, res, file=log, sep='|') @app.route('/search4', methods=['POST']) def do_search() -> str: phrase = request.form['phrase'] letters = request.form['letters'] title = 'Results' results = str(search4letters(phrase, letters)) log_request(request, results) return render_template('results.html', the_title=title, the_phrase=phrase, the_letters=letters, the_results=results,) @app.route('/') @app.route('/entry') def entry_page() -> 'html': return render_template('entry.html', the_title='Welcome to search4letters of the website version!') @app.route('/viewlog') def view_the_log() -> 'html': contents = [] with open('vsearch.log') as log: for line in log: contents.append([]) for item in line.split('|'): contents[-1].append(escape(item)) titles = ('form data', 'remote address', 'user agent', 'results') return render_template('viewlog.html', the_title='view the log', the_row_titles=titles, the_data=contents,) if __name__ == '__main__':
試したこと
def view_the_logのところを見直したのですが、
どこを間違えているかわかりませんでした。
ちなみにHTMLのテンプレートをお見せすると
以下のような感じになっています。
ソースコードは以下のようになっています。
HTML
1<!-- saved from url=(0047)http://python.itcarlow.ie/ed2/ch06/viewlog.html --> 2<html><head><meta http-equiv="Content-Type" content="text/html; charset=windows-1252"></head><body>{% extends 'base.html' %} 3 4{% block body %} 5 6<h2>{{ the_title }}</h2> 7 8 9 {% for row_title in the_row_titles %} 10 11 {% endfor %} 12 13 {% for log_row in the_data %} 14 15 {% for item in log_row %} 16 17 {% endfor %} 18 19 {% endfor %} 20<table> 21 <tbody><tr><th>{{row_title}}</th></tr><tr><td>{{item}}</td></tr></tbody></table> 22 23{% endblock %} 24</body></html>
プログラミング初心者で、
すいませんが、
何卒宜しくお願い致します。
回答1件
あなたの回答
tips
プレビュー