Flask is a microframework for Python based on Werkzeug, Jinja 2 and good intentions.
flask 是一种微框架,适合开发Web小服务。
python 3.7 安装 flask
pip install flask
以下脚本支持 Windows 中文文件名
运行 cmd
mkdir flask
cd /flask
mkdir static
mkdir templates
flask_download.py 存入 flask
# -*- coding: utf-8 -*-
import os
import sys
import glob
from flask import Flask, render_template, send_from_directory
MyFolder = '/Books'
pattern = '*.pdf'
os.chdir(MyFolder)
maps = {}
for fname in glob.glob(pattern):
if os.path.isfile(fname):
key = fname
maps[key] = os.path.getsize(fname)//1024
os.chdir('/flask')
app = Flask(__name__)
@app.route('/')
def index():
return '<a href="/download"> 文件下载 </a>'
@app.route('/download')
def filelist():
return render_template('download.htm', files=maps)
@app.route('/download/<filename>')
def download(filename):
return send_from_directory(MyFolder, filename, mimetype='application/octet-stream')
if __name__ == '__main__':
#app.run(debug=True, port=80)
app.run(debug=True, host='127.0.0.1', port=8000)
download.htm 存入 D:\flask\templates
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>download </title>
<style type="text/css">
table { border-collapse:collapse; font:12px }
th { background: #f4f4f4; cursor: pointer }
th,td { padding:5px; border:black solid 1px; white-space:nowrap }
th.sorted.ascending:after { content: " \2191" }
th.sorted.descending:after { content: " \2193" }
th.no-sort,th.no-sort:hover { background: #f4f4f4; cursor: not-allowed }
</style>
<script src="{{url_for('static', filename='jquery-1.9.0.min.js')}}"></script>
<script src="{{url_for('static', filename='jquery.tablesort.js')}}"></script>
</head>
<body>
<div class="tb1">
<table>
<thead>
<tr><th>文件名称 </th><th class="number">文件大小 Kb</th></tr>
</thead>
<tbody>
{% for k,v in files.iteritems() %}
<tr><td><a href="/download/{{k}}">{{k}} </a> </td><td>{{v}} </td></tr>
{% endfor %}
</tbody>
</table>
</div>
<script type="text/javascript">
$(function() {
$('table').tablesort().data('tablesort');
$('thead th.number').data('sortBy', function(th, td, sorter) {
return parseInt(td.text(), 10);
});
//Sorting indicator example
$('table.tb1').on('tablesort:start', function(event, tablesort) {
$('table.tb1 tbody').addClass("disabled");
$('.tb1 th.number').removeClass("sorted").text('Sorting..');
});
$('table.tb1').on('tablesort:complete', function(event, tablesort) {
$('table.tb1 tbody').removeClass("disabled");
$('.tb1 th.number').text('Number');
});
});
</script>
</body>
</html>
download.htm 去除对旧版 jquery 的依赖,经过测试也是可行的。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>download </title>
<style type="text/css">
table { border-collapse:collapse; font:12px }
th { background: #f4f4f4; cursor: pointer }
th,td { padding:5px; border:black solid 1px; white-space:nowrap }
</style>
</head>
<body>
<div class="tb1">
<table>
<thead>
<tr><th>文件名称 </th><th class="number">文件大小 Kb</th></tr>
</thead>
<tbody>
{% for k,v in files.items() %}
<tr><td><a href="/download/{{k}}">{{k}} </a> </td><td>{{v}} </td></tr>
{% endfor %}
</tbody>
</table>
</div>
</body>
</html>
运行 flask_download.py