70 lines
2.5 KiB
Python
70 lines
2.5 KiB
Python
|
|
|
|
import os
|
|
from flask import Flask, request, render_template, send_from_directory, flash, redirect, url_for
|
|
from werkzeug.utils import secure_filename
|
|
from transform_data import process_with_rounding
|
|
|
|
# --- 設定 ---
|
|
UPLOAD_FOLDER = 'uploads' # 用於儲存上傳和處理後的檔案
|
|
ALLOWED_EXTENSIONS = {'xls', 'xlsx'}
|
|
|
|
app = Flask(__name__)
|
|
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
|
|
app.config['SECRET_KEY'] = 'supersecretkey' # Flask 需要一個密鑰來顯示提示訊息
|
|
|
|
# --- 輔助函式 ---
|
|
def allowed_file(filename):
|
|
return '.' in filename and \
|
|
filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS
|
|
|
|
# --- 路由定義 ---
|
|
@app.route('/', methods=['GET', 'POST'])
|
|
def upload_file():
|
|
if request.method == 'POST':
|
|
# 檢查是否有上傳檔案
|
|
if 'file' not in request.files:
|
|
flash('沒有檔案部分')
|
|
return redirect(request.url)
|
|
file = request.files['file']
|
|
# 如果使用者未選擇檔案,瀏覽器也會送出一個沒有檔名的空檔案
|
|
if file.filename == '':
|
|
flash('未選擇檔案')
|
|
return redirect(request.url)
|
|
|
|
if file and allowed_file(file.filename):
|
|
filename = secure_filename(file.filename)
|
|
|
|
# 建立上傳資料夾 (如果不存在)
|
|
if not os.path.exists(app.config['UPLOAD_FOLDER']):
|
|
os.makedirs(app.config['UPLOAD_FOLDER'])
|
|
|
|
input_path = os.path.join(app.config['UPLOAD_FOLDER'], filename)
|
|
file.save(input_path)
|
|
|
|
# 產生最終檔案名稱
|
|
base, ext = os.path.splitext(filename)
|
|
final_filename = f"{base}_final_rounded.xlsx"
|
|
|
|
# 呼叫您既有的處理函式
|
|
try:
|
|
process_with_rounding(input_path, final_filename)
|
|
# 提供下載連結
|
|
return redirect(url_for('download_file', name=final_filename))
|
|
except Exception as e:
|
|
flash(f'處理檔案時發生錯誤: {e}')
|
|
return redirect(request.url)
|
|
|
|
return render_template('index.html')
|
|
|
|
@app.route('/uploads/<name>')
|
|
def download_file(name):
|
|
return send_from_directory(app.config['UPLOAD_FOLDER'], name)
|
|
|
|
# --- 啟動伺服器 ---
|
|
if __name__ == '__main__':
|
|
# 使用 host='0.0.0.0' 讓區域網路中的其他電腦可以存取
|
|
# 在生產環境中,建議設置 debug=False
|
|
app.run(debug=False, host='0.0.0.0', port=12001)
|
|
|