zoukankan      html  css  js  c++  java
  • flak导出excel表到本地

    功能:点击按钮,下载一个excel表到本地。且该表有固定的模板样式

    前端:

    1.index.html

    <!DOCTYPE html>
    
    
    <html lang="en">
    <head>
    {% include 'header.html' %}
        <meta charset="UTF-8">
        <!-- 使用url_for加载静态文件 url_for第一个参数必须是'static',然后后面跟一个关键字参数filename='文件路径',从static文件夹下面开始寻找的 -->
        <link rel="stylesheet" href="{{ url_for('static',filename='css/index.css') }}">
        <!-- 使用url加载静态文件,以/开头的,浏览器会自动将前面的域名,端口号补齐 -->
        <!-- <link rel="stylesheet" href="/static/css/index.css"> -->
        <!-- 使用相对路径导入静态文件? 真的可以这样导入吗? -->
    
        <!-- <script src="{{ url_for('static',filename='js/index.js') }}"></script> -->
    </head>
    <body>
    <p>static demo</p>
    <img src="{{ url_for('static',filename='images/test.png') }}" alt="" width="500px" height="500px">
    <!-- <img src="../static/images/test.png" alt="" width="500px" height="500px"> -->
            <form method="post" action="/export">
                    <input type="submit" value="print" name="print"/>
            </form>
            <!--<div class="content">-->
                <!--<button  onclick="exportData()">导出报表</button>-->
            <!--</div>-->
    </body>
     <!--导入footer.html -->
    {% include 'footer.html' %}
    
        <script src="/static/js/jquery-1.11.1.min.js"></script>
        <script>
            $(function () {
                alert('hello world');
            });
    
    
    
            function exportData() {
                $.ajax({
                    cache: true,
                    type: "POST",
                    url: "/export",
                    async: false,
                    success: function (result) {
                        console.log(result);
                        window.location.href = result;
                    },
                    complete: function () {
                    },
                    error: function (data) {
                        console.log('导出失败,请重试!');
                    }
                });
            }
        </script>
    </html>

    后端:

    1. exportdata.py

    # !/usr/bin/env python
    # -*- coding: UTF-8 -*-
    """
    点击按钮,下载一个excel表到本地。且写有固定内容
    """
    from flask import Blueprint,send_file
    import xlrd
    from xlutils.copy import copy
    
    
    bp = Blueprint("", __name__, url_prefix='/')
    
    @bp.route('/export', methods=['POST'])
    def exportExcel():
        rb = xlrd.open_workbook('static/excel/test.xls',formatting_info=True)
        wb = copy(rb)
        ws = wb.get_sheet(0)
        ws.write(2,0,'wangm')
        wb.save('static/excel/test1.xls')
    
        return send_file('static/excel/test1.xls')

    2. manage.py

    # -*- coding: UTF-8 -*-
    
    import sys
    from flask_script import Manager
    from app import app
    import flask_excel as excel
    
    from werkzeug.utils import find_modules, import_string
    
    reload(sys)
    sys.setdefaultencoding('utf8')
    manager = Manager(app)
    
    def register_blueprints():
        modules = find_modules('api', recursive=True)
        for name in modules:
            module = import_string(name)
            if hasattr(module, 'bp'):
                app.register_blueprint(module.bp)
    
    if __name__ == '__main__':
        register_blueprints()
        excel.init_excel(app)
        manager.run()
        #app.run()

    3. app.py

    # -*- coding: UTF-8 -*-
    
    from flask import Flask,render_template
    
    app = Flask(__name__)
    
    
    @app.route('/')
    def index():
        return render_template('index.html')
  • 相关阅读:
    递归初级——第39级台阶
    排序——快速排序(尾递归优化)
    排序——快速排序(优化小数组时的排序方案 )
    排序——快速排序(三数取中法和优化不必要交换)
    排序——归并排序(递归实现+迭代实现 )
    超详细Hexo+Github博客搭建小白教程
    每日算法系列【LeetCode 1031】两个非重叠子数组的最大和
    每日算法系列【LeetCode 330】按要求补齐数组
    5W2H | 关于写博客的七点反思
    每日算法系列【LeetCode 124】二叉树中的最大路径和
  • 原文地址:https://www.cnblogs.com/yoyoma0355/p/13913101.html
Copyright © 2011-2022 走看看