日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

python - 用flask+sqlalchemy查詢數(shù)據(jù)

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

問題描述

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

問題解答

回答1:

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

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

我先概括一下思路:用路由把SQLAlchemy查詢到的數(shù)據(jù)通過參數(shù)傳遞給render_template函數(shù),再在.html文件中用jinja2實(shí)現(xiàn)動態(tài)渲染網(wǎng)頁。

比如現(xiàn)在你有一個(gè)博客數(shù)據(jù)庫,你需要把博客的內(nèi)容顯示到主頁上,該如何顯示呢?

主要的方法其實(shí)是用jinja2來實(shí)現(xiàn),首先假設(shè)你有一個(gè)Post數(shù)據(jù)庫(已經(jīng)在models.py中定義好了的,別跟我說你不懂!!)

好吧你不懂,就像這樣:

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來的呀!這里懶得解釋了,直接帖個(gè)完整的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

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

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

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

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

<ul class='posts'> <!--處理從路由傳進(jìn)來的posts,用一個(gè)for循環(huán)處理,語法酷似python--> {% for post in posts %} <li class='post'><p class='post-thumbnail'> <a href='http://www.b3g6.com/wenda/{{ url_for(’.user’, username=post.author.username) }}'><img src='http://www.b3g6.com/wenda/{{ post.author.gravatar(size=40) }}'> </a></p><p class='post-content'> <!--Post數(shù)據(jù)在這里顯示,你要的答案就在這了。核心思想就是用jinja2 --> <p class='post-date'>{{ moment(post.timestamp).fromNow() }}</p> <p class='post-author'><a href='http://www.b3g6.com/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>

以前看過一點(diǎn)《Flask Web開發(fā):基于Python的Web應(yīng)用開發(fā)實(shí)戰(zhàn)》,今天小小復(fù)習(xí)一下,如果有什么不對的地方,請大家指出,謝謝!

樓主要的答案這本書里都有,也強(qiáng)烈推薦想學(xué)flask的同學(xué)看看這本書呀!

回答2:

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

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

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

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

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品亚洲欧美日韩一区在线| 亚洲一级在线| 亚洲欧美网站| 国产一区91| 亚洲一区二区三区四区五区午夜| 久久影视一区| 中文字幕系列一区| 久久蜜桃av| 亚洲婷婷在线| 亚洲精品综合| 日本欧美韩国一区三区| 精品黄色一级片| 精品一区二区三区中文字幕| 国产精品亲子伦av一区二区三区| 精品福利久久久| 成人啊v在线| 久久婷婷久久| 久久精品xxxxx| 欧美激情91| 黄色不卡一区| 欧美激情精品| 欧美aa在线观看| 激情综合网址| 免费高清在线一区| 日本不良网站在线观看| 久久亚洲风情| 国产精区一区二区| 日韩高清中文字幕一区二区| 亚洲综合精品四区| 精品中国亚洲| 激情六月综合| 麻豆中文一区二区| 快she精品国产999| 国产夫妻在线| 欧美久久精品| 激情六月综合| 久久亚洲黄色| 亚洲伊人精品酒店| zzzwww在线看片免费| 欧美日韩1区2区3区| 亚洲国产影院| 人人草在线视频| 国产麻豆一区二区三区 | 久久精品青草| 日韩精品一级中文字幕精品视频免费观看 | 四虎在线精品| 99精品小视频| 欧美激情久久久久久久久久久| 性一交一乱一区二区洋洋av| 美腿丝袜亚洲一区| 99国产精品| 日韩精品午夜| 91亚洲成人| 国产日韩欧美一区二区三区在线观看| 国产亚洲激情| 蜜桃成人精品| 青青久久av| 亚洲深夜视频| 老牛国内精品亚洲成av人片| 91亚洲无吗| 奇米亚洲欧美| 国产精品一区2区3区| 欧美日韩一区二区三区四区在线观看 | 日韩av午夜在线观看| 999国产精品| 国产成人精选| 日本欧美不卡| 美女网站一区| 伊人成人在线视频| 免费成人av在线播放| 亚洲一区亚洲| 日韩福利在线观看| 国产精品黄网站| 久久在线免费| 亚洲91久久| 国产亚洲欧洲| 日本成人精品| 蜜桃精品视频| 黄毛片在线观看| 亚洲性色视频| 日韩精品一区第一页| 日本vs亚洲vs韩国一区三区二区| 大香伊人久久精品一区二区| 精品国产欧美| 九九综合九九| 欧美日韩亚洲一区| 国产成人精品亚洲线观看 | 日韩高清三区| 91欧美日韩在线| 极品av在线| 午夜免费一区| 97se亚洲| 欧美 日韩 国产一区二区在线视频 | 日韩二区三区在线观看| av在线资源| 日本亚洲欧洲无免费码在线| 久久免费影院| 亚洲图片久久| 99国产精品一区二区| 日韩不卡一二三区| 亚洲激情中文| 国产成人精品亚洲线观看 | 欧美日韩尤物久久| 99re国产精品| 超级白嫩亚洲国产第一| 日韩一区二区三区四区五区| 久久精品理论片| 婷婷综合成人| 亚洲成人日韩| 欧美精品日日操| 精品久久亚洲| 久久的色偷偷| 欧美日韩 国产精品| 麻豆久久精品| 欧美一区二区三区高清视频| 另类专区亚洲| 成人综合一区| 国产中文字幕一区二区三区| 日韩av一区二区三区四区| 亚洲激情不卡| 亚洲主播在线| 视频一区中文| 亚洲大全视频| 最新国产拍偷乱拍精品| 亚洲精品午夜av福利久久蜜桃| 欧美午夜不卡影院在线观看完整版免费| 精品一区91| 国产伦理一区| 丝袜美腿亚洲一区二区图片| 成人av二区| 日韩一区二区久久| 久久av一区二区三区| 国产亚洲福利| 视频国产精品| 88久久精品| 精品免费视频| 成人午夜网址| 欧美一级精品| 亚洲一级大片| 国产精品黄色片| 中文字幕高清在线播放| 日韩中文在线播放| 黑丝一区二区三区| 四虎精品一区二区免费| 国产精品一级在线观看| 日韩福利一区| 国产亚洲精品v| 国产日韩欧美一区二区三区| 日韩av自拍| 99re国产精品| 亚洲欧洲免费| 欧美日韩中出| 国精品一区二区三区| 日韩黄色av| 91免费精品| 蜜桃av一区二区在线观看| 亚洲精品福利| 97精品中文字幕| 免费观看日韩电影| 国产精品99久久精品| 久久成人精品| 在线天堂中文资源最新版| 亚洲资源网站| 欧美日韩视频免费观看| 一区二区精品| av综合电影网站| 日韩中文字幕亚洲一区二区va在线| 91视频精品| 亚洲欧美一级| 久久人人88| 国产成人精品一区二区免费看京| 日韩av成人高清| 亚洲特级毛片| 国产精品13p| 国产精品入口久久| 亚洲三级av| 亚洲精品在线观看91| 久久久国产精品网站| 老司机免费视频一区二区| 国产欧美一区二区三区精品酒店| 国产美女一区| 精品久久91| 国产精品99久久久久久董美香| 视频一区在线播放| av资源亚洲| 国产精品成人a在线观看| 亚洲精品九九| 亚洲综合国产| 欧美日韩四区| 亚洲国产日韩欧美在线| 久久天堂精品| 国产99久久| 午夜欧美精品久久久久久久| 136国产福利精品导航网址| 日韩国产在线| www.51av欧美视频| 精品视频网站| 不卡专区在线| 国模 一区 二区 三区| 最新国产拍偷乱拍精品|