国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python - 用flask+sqlalchemy查詢數據

瀏覽:86日期:2022-07-03 17:47:16

問題描述

再我登陸計入到主頁面后,主頁面的數據是用form表單接收的嗎?查到的數據不知道怎么放到頁面上,有沒有什么資料推薦一下,或者是給點指導

問題解答

回答1:

我想把從數據庫查到的數據顯示到頁面上,我想知道是不是用form提交上去的?找不到參考資料

我將根據這一句話來回答樓主的問題。

我先概括一下思路:用路由把SQLAlchemy查詢到的數據通過參數傳遞給render_template函數,再在.html文件中用jinja2實現動態渲染網頁。

比如現在你有一個博客數據庫,你需要把博客的內容顯示到主頁上,該如何顯示呢?

主要的方法其實是用jinja2來實現,首先假設你有一個Post數據庫(已經在models.py中定義好了的,別跟我說你不懂!?。?/p>

好吧你不懂,就像這樣:

from . import dbclass Post(db.Model): __tablename__ = ’posts’ id = db.Column(db.Integer, primary_key=True) body = db.Column(db.Text) body_html = db.Column(db.Text) timestamp = db.Column(db.DateTime, index=True, default=datetime.utcnow) author_id = db.Column(db.Integer, db.ForeignKey(’users.id’)) comments = db.relationship(’Comment’, backref=’post’, lazy=’dynamic’) db.event.listen(Post.body, ’set’, Post.on_changed_body)

什么你不懂db是哪里import來的?是app包里__init__.py來的呀!這里懶得解釋了,直接帖個完整的init方法吧

from flask import Flaskfrom flask_bootstrap import Bootstrapfrom flask_mail import Mailfrom flask_moment import Momentfrom flask_sqlalchemy import SQLAlchemyfrom flask_login import LoginManagerfrom flask_pagedown import PageDownfrom config import configbootstrap = Bootstrap()mail = Mail()moment = Moment()db = SQLAlchemy()pagedown = PageDown()login_manager = LoginManager()login_manager.session_protection = ’strong’login_manager.login_view = ’auth.login’def create_app(config_name): app = Flask(__name__) app.config.from_object(config[config_name]) config[config_name].init_app(app) bootstrap.init_app(app) mail.init_app(app) moment.init_app(app) db.init_app(app) login_manager.init_app(app) pagedown.init_app(app) if not app.debug and not app.testing and not app.config[’SSL_DISABLE’]:from flask_sslify import SSLifysslify = SSLify(app) from .main import main as main_blueprint app.register_blueprint(main_blueprint) from .auth import auth as auth_blueprint app.register_blueprint(auth_blueprint, url_prefix=’/auth’) from .api_1_0 import api as api_1_0_blueprint app.register_blueprint(api_1_0_blueprint, url_prefix=’/api/v1.0’) return app

不過更改數據庫記得先運行python manager.py shell來遷移一下數據庫呀(具體的自己查去)扯遠了,我們來看樓主的問題。

首先來看路由(就是views.py)中的內容:

@main.route(’/’, methods=[’GET’, ’POST’])def index(): #前面已經假設了你有個Post數據庫 query = Post.query #這里使用了pagination,就是自動實現翻頁的一個擴展,可用可不用哈 pagination = query.order_by(Post.timestamp.desc()).paginate(page, per_page=current_app.config[’FLASKY_POSTS_PER_PAGE’],error_out=False) #這里才是重點,簡單來說就是讓posts=Post.query.order_by(Post.timestamp.desc()) posts = pagination.items #然后用render_template傳給html,交給jinja2來動態渲染 return render_template(’index.html’, form=form, posts=posts, show_followed=show_followed, pagination=pagination)

現在讓我們到index.html中來看看jinja2該如何工作,不過為了讓index.html看上去盡量簡潔,我將打印Post的模塊單獨提了出來,叫_post.html,在index.html中使用只要{% include ’_posts.html’ %}即可:讓我們來看_post.html

<ul class='posts'> <!--處理從路由傳進來的posts,用一個for循環處理,語法酷似python--> {% for post in posts %} <li class='post'><p class='post-thumbnail'> <a href='http://www.cgvv.com.cn/wenda/{{ url_for(’.user’, username=post.author.username) }}'><img src='http://www.cgvv.com.cn/wenda/{{ post.author.gravatar(size=40) }}'> </a></p><p class='post-content'> <!--Post數據在這里顯示,你要的答案就在這了。核心思想就是用jinja2 --> <p class='post-date'>{{ moment(post.timestamp).fromNow() }}</p> <p class='post-author'><a href='http://www.cgvv.com.cn/wenda/{{ url_for(’.user’, username=post.author.username) }}'>{{ post.author.username }}</a></p> <p class='post-body'>{% if post.body_html %} {{ post.body_html | safe }}{% else %} {{ post.body }}{% endif %} </p></p> </li> {% endfor %}</ul>

以前看過一點《Flask Web開發:基于Python的Web應用開發實戰》,今天小小復習一下,如果有什么不對的地方,請大家指出,謝謝!

樓主要的答案這本書里都有,也強烈推薦想學flask的同學看看這本書呀!

回答2:

比如你訪問的是/index頁面,你肯定會有一個后端,一個前端給你提供思路,你自己去找相關資料,搜索引擎搜索flask開發

@app.route(’/index’)def index(): data = '從數據庫讀取出來的數據' html = [] for item in data:html.append(item.'列名') return ’’.join(html)回答3:

你接受參數,可以用路由里面的變量,也可以用request.args.get命令獲取參數。然后執行程序獲得結果,當然最簡單的就是拼接成字符串直接用return,當然更正式的是用render_template ,配合jinjia2渲染模板輸出。

這個還是看下flask的快速入門吧。http://docs.jinkan.org/docs/f...

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲欧洲日产v特级毛片 | 在线一区二区观看 | 美国欧美一级毛片 | 夜色福利久久久久久777777 | 99久久精品国产国产毛片 | 亚洲精品一级片 | 久久一日本道色综合久久 | 新26uuu在线亚洲欧美 | 91色综合久久 | 日本天堂网址 | 免费国产成人高清在线观看视频 | 中文成人在线视频 | 亚洲综合视频在线观看 | 国产一区二区三区精品视频 | 欧美国产精品不卡在线观看 | 久草在线 | 久久国内免费视频 | 久草免费在线视频观看 | 亚洲毛片免费在线观看 | 97视频免费播放观看在线视频 | 国产原创在线视频 | 精品外国呦系列在线观看 | 男女牲高爱潮免费视频男女 | 三级毛片大全 | 免费看欧美成人性色生活片 | 免费大片黄手机在线观看 | 一区二区三区免费在线视频 | 欧美a欧美 | 国产自一区 | 欧美日韩精品一区三区 | 美女黄色毛片免费看 | 色综合久久久高清综合久久久 | 国产亚洲精品一品区99热 | 亚洲视频一区二区在线观看 | 日韩亚洲一区中文字幕 | 久草国产在线视频 | 日本不卡一二三区 | 国产精品成人网 | 国产护士一级毛片高清 | 99re6这里有精品热视频在线 | 毛片无码国产 |