首頁  >  問答  >  主體

python - 用flask+sqlalchemy查詢數據

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

怪我咯怪我咯2711 天前895

全部回覆(3)我來回復

  • 大家讲道理

    大家讲道理2017-05-18 11:01:39

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

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

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

    例如現在你有一個部落格資料庫,你需要把部落格的內容顯示到主頁上,該如何顯示呢?

    主要的方法其實是用jinja2来实现,首先假设你有一个Post数据库(已经在models.py中定義好了的,別跟我說你不懂! ! )

    好吧你不懂,就像這樣:

    from . import db
    
    class 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 Flask
    from flask_bootstrap import Bootstrap
    from flask_mail import Mail
    from flask_moment import Moment
    from flask_sqlalchemy import SQLAlchemy
    from flask_login import LoginManager
    from flask_pagedown import PageDown
    from config import config
    
    bootstrap = 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 SSLify
            sslify = 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' %}< /code>即可:index.html中来看看jinja2该如何工作,不过为了让index.html看上去尽量简洁,我将打印Post的模块单独提了出来,叫_post.html,在index.html中使用只要{% include '_posts.html' %}即可:
    让我们来看_post.html讓我們來看_post.html

    <ul class="posts">
        <!--处理从路由传进来的posts,用一个for循环处理,语法酷似python-->
        {% for post in posts %}
        <li class="post">
            <p class="post-thumbnail">
                <a href="{{ url_for('.user', username=post.author.username) }}">
                    <img class="img-rounded profile-thumbnail" src="{{ 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="{{ 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的同學看看這本書呀!

    回覆
    0
  • PHP中文网

    PHP中文网2017-05-18 11:01:39

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

    @app.route('/index')
    def index():
        data = "从数据库读取出来的数据"
        html = []
        for item in data:
            html.append(item."列名")
        return ''.join(html)

    回覆
    0
  • 为情所困

    为情所困2017-05-18 11:01:39

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

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

    回覆
    0
  • 取消回覆