import math
from flask import Blueprint, jsonify, request
from flask import render_template
from sqlalchemy import not_, and_, or_, text
from ..model import Csdn # 导入上级模块
from app import db
cs = Blueprint('csdn', __name__, url_prefix='/csdn')
nav = dict();
nav['csdn'] = 'active'
@cs.route('/blogstar')
def user_list():
user = []
page = request.args.get("page", 0)
try:
page = int(page)
except Exception as e:
return "what are you 弄啥嘞? 返回首页", 403
if page == 0:
user = Csdn.query.order_by(-Csdn.totalScore).all()
elif page == 1:
user = Csdn.query.filter(Csdn.cateName == "IT其他").order_by(-Csdn.totalScore).all()
elif page == 2:
user = Csdn.query.filter(Csdn.cateName == "前端").order_by(-Csdn.totalScore).all()
elif page == 3:
user = Csdn.query.filter(Csdn.cateName == "后端").order_by(-Csdn.totalScore).all()
elif page == 4:
user = Csdn.query.filter(Csdn.cateName == "大数据与算法").order_by(-Csdn.totalScore).all()
elif page == 5:
user = Csdn.query.filter(Csdn.cateName == "云原生与云平台").order_by(-Csdn.totalScore).all()
elif page == 6:
user = Csdn.query.filter(Csdn.cateName == "前沿技术").order_by(-Csdn.totalScore).all()
elif page == 7:
user = Csdn.query.filter(Csdn.cateName == "人工智能").order_by(-Csdn.totalScore).all()
elif page == 8:
user = Csdn.query.filter(Csdn.cateName == "运维与安全").order_by(-Csdn.totalScore).all()
elif page == 9:
user = Csdn.query.filter(Csdn.cateName == "移动开发").order_by(-Csdn.totalScore).all()
elif page == 10:
user = Csdn.query.filter(Csdn.cateName == "物联网与嵌入式").order_by(-Csdn.totalScore).all()
for u in user:
if u.regtime is not None:
u.star = "博客新星" if u.regtime.startswith("2022") else "博客之星"
else:
u.star = "---"
bg_green = 200 if page == 0 else 10
return render_template('csdn/blogstar.html', user=user, bg_green=bg_green, nav=nav)
@cs.route('/newstar')
def new_star_list():
user = Csdn.query.order_by(-Csdn.totalScore).filter(Csdn.regtime.startswith("2022")).all()
return render_template('csdn/newstar.html', user=user, nav=nav)
@cs.route('/zong')
def zong_star_list():
user = []
t = request.args.get("t", 0)
try:
t = int(t)
except Exception as e:
return "what are you 弄啥嘞? 返回首页", 403
if t == 0:
user = Csdn.query.order_by(-Csdn.totalScore).all()
elif t == 1:
user = Csdn.query.order_by(-Csdn.yuanli).all()
elif t == 2:
user = Csdn.query.order_by(-Csdn.fensi).all()
elif t == 3:
user = Csdn.query.order_by(-Csdn.fangwen).all()
elif t == 4:
user = Csdn.query.order_by(-Csdn.yuanchuang).all()
elif t == 5:
user = Csdn.query.order_by(Csdn.zongbang).all()
elif t == 6:
user = Csdn.query.order_by(-Csdn.tie).all()
elif t == 7:
# sql = "SELECT * FROM score ORDER BY CONVERT(ip USING gbk) DESC"
sql = "SELECT * FROM score ORDER BY CONVERT(ip USING gbk) DESC"
result = db.engine.execute(text(sql))
user = [row for row in result]
"""
按原力排名
按粉丝排名
按访问数排名
按文章数排名
按总榜数排名
按铁粉数排名
按省市排序
"""
return render_template('csdn/blogstar_d.html', user=user, nav=nav)
from datetime import date, timedelta
@cs.route('/rank')
def column():
yesterday = (date.today() + timedelta(days=-1)).strftime("%Y-%m-%d")
sql = text(f"""select * from (
select zhuanlan_user,sum(price) as total,count(id) as ren from subscribe where subscribe_time like '{yesterday}%'
GROUP BY zhuanlan_user
ORDER BY total desc
limit 50
) abc
LEFT JOIN zhuanlan z ON z.userName = abc.zhuanlan_user""")
result = db.engine.execute(sql)
data = result.fetchall()
nav['csdn'] = ''
nav['csdn_col'] = 'active'
return render_template('csdn/rank.html', data=data, nav=nav, yesterday=yesterday)
@cs.route('/m_rank')
def m_column():
yesterday = (date.today() + timedelta(days=-1)).strftime("%Y-%m")
sql = text(f"""select * from (
select zhuanlan_user,sum(price) as total,count(id) as ren from subscribe where subscribe_time like '{yesterday}%'
GROUP BY zhuanlan_user
ORDER BY total desc
limit 50
) abc
LEFT JOIN zhuanlan z ON z.userName = abc.zhuanlan_user""")
result = db.engine.execute(sql)
data = result.fetchall()
sql2 = text(f"""
select title,count(id) n from subscribe where subscribe_time like '{yesterday}%' GROUP BY title
ORDER BY n desc limit 10 """)
result2 = db.engine.execute(sql2)
data2 = result2.fetchall()
nav['csdn'] = ''
nav['csdn_col'] = 'active'
return render_template('csdn/m_rank.html', data=data, nav=nav, yesterday=yesterday, hot_col=data2)