risk_router.py 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends,Query, HTTPException, status,BackgroundTasks
  4. from common.security import valid_access_token
  5. from fastapi.responses import JSONResponse,StreamingResponse
  6. from common.db import db_czrz
  7. from common.auth_user import *
  8. from sqlalchemy.orm import Session
  9. from sqlalchemy import and_, or_
  10. from pydantic import BaseModel
  11. from datetime import datetime
  12. from database import get_db
  13. from typing import List
  14. from models import *
  15. from utils import *
  16. from utils.ry_system_util import *
  17. from utils.riskManagement_uitl import *
  18. import json
  19. import traceback
  20. router = APIRouter()
  21. @router.get('/list')
  22. async def get_inspection_task_list(
  23. type: str = Query(None, description='类型'),
  24. cycle :str = Query(None, description='周期'),
  25. page: int = Query(1, gt=0, description='页码'),
  26. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  27. db: Session = Depends(get_db),
  28. user_id = Depends(valid_access_token)
  29. ):
  30. try:
  31. # 构建查询
  32. query = db.query(RiskManagementRiskTask)
  33. query = query.filter(RiskManagementRiskTask.del_flag != '2')
  34. # 应用查询条件
  35. if type:
  36. query = query.filter(RiskManagementRiskTask.risk_type == type)
  37. if cycle:
  38. query = query.filter(RiskManagementRiskTask.task_cycle == cycle)
  39. # 计算总条目数
  40. total_items = query.count()
  41. # 排序
  42. query = query.order_by(RiskManagementRiskTask.create_time.desc())
  43. # 执行分页查询
  44. RiskTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  45. # 将查询结果转换为列表形式的字典
  46. RiskTasks_list = []
  47. for task in RiskTasks:
  48. if task.task_status=='3':
  49. task_status = '3' #'已完结'
  50. else:
  51. if datetime.now()<task.start_time:
  52. task_status = '0' #'未开始'
  53. elif task.start_time<=datetime.now()<=task.end_time:
  54. task_status = '1' #'进行中'
  55. else:
  56. task_status = '2' #'未完成'
  57. create_by = task.create_by
  58. create_by = db.query(SysUser).filter(SysUser.user_id==create_by).first()
  59. nick_name = None
  60. if create_by:
  61. nick_name=create_by.nick_name
  62. task_info = {
  63. "id": task.id,
  64. "task_number": task.task_number,
  65. "type": task.risk_type,
  66. "task_time": '%s-%s'%(task.start_time.strftime('%Y/%m/%d'),task.end_time.strftime('%Y/%m/%d')),
  67. "cycle": task.task_cycle,
  68. "task_range": task.task_range,
  69. "corn_query":task.corn_query,
  70. "task_status": task_status,
  71. "create_by":nick_name,
  72. "create_time": task.create_time#.strftime('%Y-%m-%d')
  73. }
  74. RiskTasks_list.append(task_info)
  75. # 返回结果
  76. return {
  77. "code": 200,
  78. "msg": "成功",
  79. "data": RiskTasks_list,
  80. "total": total_items,
  81. "page": page,
  82. "pageSize": pageSize,
  83. "totalPages": (total_items + pageSize - 1) // pageSize
  84. }
  85. except Exception as e:
  86. # 处理异常
  87. traceback.print_exc()
  88. raise HTTPException(status_code=500, detail=str(e))
  89. @router.get('/{id}')
  90. async def get_inspection_task(
  91. id: str ,
  92. db: Session = Depends(get_db),
  93. user_id = Depends(valid_access_token)
  94. ):
  95. try:
  96. # 构建查询
  97. query = db.query(RiskManagementRiskTask)
  98. query = query.filter(RiskManagementRiskTask.del_flag != '2')
  99. # 应用查询条件
  100. if id:
  101. query = query.filter(RiskManagementRiskTask.id == id)
  102. # 执行查询
  103. task = query.first()
  104. if not task:
  105. detail = "任务不存在"
  106. raise HTTPException(status_code=404, detail="任务不存在")
  107. # 将查询结果转换为列表形式的字典
  108. if task.task_status == '3':
  109. task_status = '3' # '已完结'
  110. else:
  111. if datetime.now() < task.start_time:
  112. task_status = '0' # '未开始'
  113. elif task.start_time <= datetime.now() <= task.end_time:
  114. task_status = '1' # '进行中'
  115. else:
  116. task_status = '2' # '未完成'
  117. create_by = task.create_by
  118. create_by = db.query(SysUser).filter(SysUser.user_id == create_by).first()
  119. nick_name = None
  120. if create_by:
  121. nick_name = create_by.nick_name
  122. risk_task_result = {
  123. "id": task.id,
  124. "task_number": task.task_number,
  125. "type": task.risk_type,
  126. "task_time": '%s-%s'%(task.start_time.strftime('%Y/%m/%d'),task.end_time.strftime('%Y/%m/%d')),
  127. "cycle": task.task_cycle,
  128. "task_range": task.task_range,
  129. "corn_query":task.corn_query,
  130. "task_status": task_status,
  131. "create_by":nick_name,
  132. "create_time": task.create_time.strftime('%Y-%m-%d')
  133. }
  134. # 返回结果
  135. return {
  136. "code": 200,
  137. "msg": "成功",
  138. "data": risk_task_result
  139. }
  140. except Exception as e:
  141. # 处理异常
  142. traceback.print_exc()
  143. if str(e)=='':
  144. e = detail
  145. raise HTTPException(status_code=500, detail=str(e))
  146. @router.post('/create')
  147. async def create_inspection_task(
  148. background_tasks: BackgroundTasks,
  149. db: Session = Depends(get_db),
  150. body = Depends(remove_xss_json),
  151. user_id = Depends(valid_access_token)
  152. ):
  153. try:
  154. cycle = body['cycle']
  155. # 0每年、1每月、2每周、3每日、4一次
  156. corn_query = body['corn_query']
  157. if cycle=='0':
  158. corn=f'0 0 {corn_query} *'
  159. elif cycle=='1':
  160. corn=f'0 0 {corn_query} * *'
  161. elif cycle == '2':
  162. corn = f'0 0 * * {corn_query}'
  163. elif cycle == '3':
  164. corn = f'0 0 * * *'
  165. else:
  166. corn=''
  167. # 创建新的预案记录
  168. new_task = RiskManagementRiskTask(
  169. risk_type=body['type'],
  170. start_time = body['start_time'],
  171. end_time = body['end_time'],
  172. task_cycle = cycle,
  173. corn_query= corn_query,
  174. corn_expression = corn,
  175. task_range = body['task_range'],
  176. task_status = '-1',
  177. create_by = user_id
  178. )
  179. # 添加到数据库会话并提交
  180. db.add(new_task)
  181. db.commit()
  182. db.refresh(new_task) # 可选,如果需要刷新实例状态
  183. new_task.task_number = f'YJFX{str(new_task.id).zfill(10)}'
  184. db.commit()
  185. background_tasks.add_task(create_risk_children_task,db,new_task,corn_query)
  186. # 返回创建成功的响应
  187. return {
  188. "code": 200,
  189. "msg": "成功",
  190. "data": None
  191. }
  192. except Exception as e:
  193. # 处理异常
  194. traceback.print_exc()
  195. raise HTTPException(status_code=500, detail=str(e))
  196. @router.put('/update')
  197. async def update_inspection_task(
  198. db: Session = Depends(get_db),
  199. body = Depends(remove_xss_json),
  200. user_id = Depends(valid_access_token)
  201. ):
  202. try:
  203. # 提取请求数据
  204. query = db.query(RiskManagementRiskTask)
  205. query = query.filter(RiskManagementRiskTask.id == body['id'])
  206. query = query.filter(RiskManagementRiskTask.del_flag != '2')
  207. task = query.first()
  208. if not task:
  209. detail = "任务不存在"
  210. raise HTTPException(status_code=404, detail="任务不存在")
  211. # if 'cycle' in body:
  212. # cycle = body['cycle']
  213. # # 0每年、1每月、2每周、3每日、4一次
  214. # corn_query = body['corn_query']
  215. # if cycle == '0':
  216. # corn = f'0 0 {corn_query} *'
  217. # elif cycle == '1':
  218. # corn = f'0 0 {corn_query} * *'
  219. # elif cycle == '2':
  220. # corn = f'0 0 * * {corn_query}'
  221. # elif cycle == '3':
  222. # corn = f'0 0 * * *'
  223. # else:
  224. # corn = ''
  225. # task.inspection_cycle = cycle
  226. # task.corn_expression = corn
  227. if 'type' in body:
  228. task.risk_type = body['type']
  229. # if 'start_time' in body:
  230. # task.start_time = body['start_time']
  231. # if 'end_time' in body:
  232. # task.end_time = body['end_time']
  233. if 'task_range' in body:
  234. task.task_range = body['task_range']
  235. if 'task_status' in body:
  236. task.task_status = body['task_status']
  237. if user_id:
  238. task.update_by = user_id
  239. # 更新到数据库会话并提交
  240. db.commit()
  241. db.refresh(task) # 可选,如果需要刷新实例状态
  242. # 返回创建成功的响应
  243. return {
  244. "code": 200,
  245. "msg": "成功",
  246. "data": None
  247. }
  248. except Exception as e:
  249. # 处理异常
  250. traceback.print_exc()
  251. if str(e)=='':
  252. e = detail
  253. raise HTTPException(status_code=500, detail=str(e))
  254. @router.delete('/delete')
  255. async def delete_inspection_tasks(
  256. taskIds: list,
  257. db: Session = Depends(get_db),
  258. body = Depends(remove_xss_json),
  259. user_id = Depends(valid_access_token)
  260. ):
  261. try:
  262. # 提取请求数据
  263. query = db.query(RiskManagementRiskTask)
  264. query = query.filter(RiskManagementRiskTask.del_flag != '2')
  265. query = query.filter(RiskManagementRiskTask.id.in_(taskIds))
  266. tasks = query.all()
  267. if not tasks:
  268. detail = "任务不存在"
  269. raise HTTPException(status_code=404, detail="任务不存在")
  270. for task in tasks:
  271. task.del_flag = '2'
  272. task.update_by=user_id
  273. # 更新到数据库会话并提交
  274. db.commit()
  275. # 返回创建成功的响应
  276. return {
  277. "code": 200,
  278. "msg": "删除成功",
  279. "data": None
  280. }
  281. except Exception as e:
  282. # 处理异常
  283. if str(e) == '':
  284. e = detail
  285. raise HTTPException(status_code=500, detail=str(e))
  286. @router.delete('/delete/{userId}')
  287. async def delete_inspection_task(
  288. userId: str,
  289. db: Session = Depends(get_db),
  290. body = Depends(remove_xss_json),
  291. user_id = Depends(valid_access_token)
  292. ):
  293. try:
  294. # 提取请求数据
  295. query = db.query(RiskManagementRiskTask)
  296. query = query.filter(RiskManagementRiskTask.del_flag != '2')
  297. query = query.filter(RiskManagementRiskTask.id==userId)
  298. task = query.first()
  299. if not task:
  300. detail = "任务不存在"
  301. raise HTTPException(status_code=404, detail="任务不存在")
  302. task.del_flag = '2'
  303. task.update_by = user_id
  304. # 更新到数据库会话并提交
  305. db.commit()
  306. db.refresh(task) # 可选,如果需要刷新实例状态
  307. # 返回创建成功的响应
  308. return {
  309. "code": 200,
  310. "msg": "删除成功",
  311. "data": None
  312. }
  313. except Exception as e:
  314. # 处理异常
  315. traceback.print_exc()
  316. if str(e) == '':
  317. e = detail
  318. raise HTTPException(status_code=500, detail=str(e))
  319. ####小屏子任务查询
  320. @router.get('/children/task/list')
  321. async def get_risk_task_list(
  322. type: str =Query(None, description='类型'),
  323. page: int = Query(1, gt=0, description='页码'),
  324. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  325. db: Session = Depends(get_db),
  326. user_id = Depends(valid_access_token)
  327. ):
  328. try:
  329. # 构建查询
  330. # 查询用户负责层级
  331. task_range = user_id_get_task_range(db,user_id)
  332. #查询未办结巡查任务列表
  333. Task_list = db.query(RiskManagementRiskTask)\
  334. .filter(RiskManagementRiskTask.del_flag!='2')\
  335. .filter(RiskManagementRiskTask.task_range.in_(task_range))\
  336. .filter(RiskManagementRiskTask.task_status!='3').all()
  337. #获取所有巡查任务id
  338. task_ids = [i.id for i in Task_list]
  339. #用户所有负责的区域
  340. user_area_code_list = db.query(RiskManagementInspectionUser)\
  341. .filter(RiskManagementInspectionUser.del_flag!='2')\
  342. .filter(RiskManagementInspectionUser.user_id==user_id).all()
  343. user_area_codes = [i.area_code for i in user_area_code_list]
  344. #查询子任务
  345. query = db.query(RiskManagementRiskTaskChildrenTask)
  346. query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
  347. # 应用查询条件
  348. # 查询小于今天
  349. query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time <=datetime.now())
  350. # 查询层级、未办结子任务
  351. query = query.filter(RiskManagementRiskTaskChildrenTask.task_range.in_(task_range))
  352. query = query.filter(RiskManagementRiskTaskChildrenTask.task_id.in_(task_ids))
  353. # 计算总条目数
  354. if type:
  355. query = query.filter(RiskManagementRiskTaskChildrenTask.type==type)
  356. total_items = query.count()
  357. # 排序
  358. query = query.order_by(RiskManagementRiskTaskChildrenTask.tsak_time.asc())
  359. # 执行分页查询
  360. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  361. # 将查询结果转换为列表形式的字典
  362. InspectionTasks_list = []
  363. for task in InspectionTasks:
  364. # 判断这个任务该user_id完成了没
  365. tasklog = db.query(RiskManagementRiskTaskChildrenTaskLog).\
  366. filter(RiskManagementRiskTaskChildrenTaskLog.del_flag!='2').\
  367. filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id==task.id).\
  368. filter(RiskManagementRiskTaskChildrenTaskLog.area_code.in_(user_area_codes)).all()
  369. task_area_code_list = [i.area_code for i in tasklog]
  370. query = db.query(RiskManagementInspectionUser)\
  371. .filter(RiskManagementInspectionUser.del_flag!='2')\
  372. .filter(RiskManagementInspectionUser.user_id==user_id)
  373. if task.task_range == '0' and '440900000000' not in task_area_code_list:
  374. user_range_area_codes= ['440900000000']
  375. elif task.task_range == '1':
  376. query = query.filter(
  377. and_(RiskManagementInspectionUser.area_code.like('%000000'),
  378. RiskManagementInspectionUser.area_code.notlike('%00000000'),
  379. ~RiskManagementInspectionUser.area_code.in_(task_area_code_list)))
  380. user_range_area_codes= list({i.area_code for i in query.all()})
  381. elif task.task_range == '2':
  382. query = query.filter(and_(RiskManagementInspectionUser.area_code.like('%000'),
  383. RiskManagementInspectionUser.area_code.notlike('%000000'),
  384. ~RiskManagementInspectionUser.area_code.in_(task_area_code_list)))
  385. user_range_area_codes= list({i.area_code for i in query.all()})
  386. elif task.task_range == '3':
  387. query = query.filter(RiskManagementInspectionUser.area_code.notlike('%000'),
  388. ~RiskManagementInspectionUser.area_code.in_(task_area_code_list))
  389. user_range_area_codes= list({i.area_code for i in query.all()})
  390. else:
  391. user_range_area_codes= []
  392. for area_code in user_range_area_codes:
  393. task_info = {
  394. "id": task.id,
  395. "type": task.type,
  396. "task_range": task.task_range,
  397. "cycle": task.cycle,
  398. "area_code":area_code,
  399. "area": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
  400. "task_time": task.tsak_time.strftime('%Y-%m-%d'),
  401. "create_time": task.create_time.strftime('%Y-%m-%d')
  402. }
  403. InspectionTasks_list.append(task_info)
  404. # 返回结果
  405. return {
  406. "code": 200,
  407. "msg": "成功",
  408. "data": InspectionTasks_list,
  409. "total": total_items,
  410. "page": page,
  411. "pageSize": pageSize,
  412. "totalPages": (total_items + pageSize - 1) // pageSize
  413. }
  414. except Exception as e:
  415. # 处理异常
  416. traceback.print_exc()
  417. raise HTTPException(status_code=500, detail=str(e))
  418. ##日历
  419. @router.get('/children/task/calendar/list')
  420. async def get_inspection_task_list(
  421. year_1: int =Query(None, description='年份'),
  422. month_1: int =Query(None, description='月份'),
  423. # page: int = Query(1, gt=0, description='页码'),
  424. # pageSize: int = Query(10, gt=0, description='每页条目数量'),
  425. db: Session = Depends(get_db),
  426. user_id = Depends(valid_access_token)
  427. ):
  428. try:
  429. # 构建查询
  430. import datetime as datetime_1
  431. task_range = user_id_get_task_range(db,user_id)
  432. Task_list = db.query(RiskManagementRiskTask).\
  433. filter(RiskManagementRiskTask.del_flag!='2').\
  434. filter(RiskManagementRiskTask.task_range.in_(task_range)).all() #.filter(RiskManagementInspectionTask.task_status!='3')
  435. task_ids = [i.id for i in Task_list]
  436. user_area_code_list = db.query(RiskManagementInspectionUser).\
  437. filter(RiskManagementInspectionUser.del_flag!='2').\
  438. filter(RiskManagementInspectionUser.user_id==user_id).all()
  439. user_area_codes = [i.area_code for i in user_area_code_list]
  440. query = db.query(RiskManagementRiskTaskChildrenTask)
  441. query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
  442. # 应用查询条件
  443. current_date = datetime.today()
  444. if year_1 is None:
  445. year_1 =current_date.year
  446. if month_1 is None:
  447. month_1 = current_date.month
  448. if month_1 == 12:
  449. query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time < datetime_1.date(year_1+1, 1, 1))
  450. else:
  451. query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time < datetime_1.date(year_1, month_1 + 1, 1))
  452. query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time >= datetime_1.date(year_1, month_1, 1))
  453. # query = query.filter(RiskManagementInspectionTaskChildrenTask.tsak_time <=datetime.now())
  454. query = query.filter(RiskManagementRiskTaskChildrenTask.task_range.in_(task_range))
  455. query = query.filter(RiskManagementRiskTaskChildrenTask.task_id.in_(task_ids))
  456. # 计算总条目数
  457. total_items = query.count()
  458. print(total_items)
  459. result = []
  460. # 获取指定月份的第一天是周几
  461. # first_day = datetime.date(yaer_1, month_1, 1)
  462. # 计算该月的天数
  463. if month_1 == 12:
  464. number_of_days = (datetime_1.date(year_1+1, 1, 1) - datetime_1.timedelta(days=1)).day
  465. else:
  466. number_of_days = (datetime_1.date(year_1, month_1 + 1, 1) - datetime_1.timedelta(days=1)).day
  467. # 遍历该月的每一天
  468. for day in range(1, number_of_days + 1):
  469. # 创建日期对象
  470. date_obj = datetime_1.date(year_1, month_1, day)
  471. # 获取星期(0是周一,6是周日)
  472. week_day = date_obj.weekday()
  473. # 将星期转换为中文
  474. week_day_cn = "一二三四五六日"[week_day]
  475. data = {"day":day,"date":f"{year_1}-{month_1}-{day}","week":f'周{week_day_cn}',"status":0}
  476. if date_obj==datetime_1.date.today():
  477. data['status']=4
  478. # 排序
  479. # total_items = query.count()
  480. # print( '前',total_items)
  481. # print(datetime_1.date(year_1, month_1, day))
  482. query_1 = query.filter(
  483. RiskManagementRiskTaskChildrenTask.tsak_time == datetime_1.date(year_1, month_1, day))
  484. # query = query.order_by(RiskManagementInspectionTaskChildrenTask.tsak_time.asc())
  485. # total_items = query_1.count()
  486. # print( '后',total_items)
  487. InspectionTasks = query_1.all()
  488. # 将查询结果转换为列表形式的字典
  489. InspectionTasks_list = []
  490. for task in InspectionTasks:
  491. # 判断这个任务该user_id完成了没
  492. # tasklog = db.query(RiskManagementInspectionTaskChildrenTaskLog).\
  493. # filter(RiskManagementInspectionTaskChildrenTaskLog.del_flag!='2').\
  494. # filter(RiskManagementInspectionTaskChildrenTaskLog.children_task_id==task.id).\
  495. # filter(RiskManagementInspectionTaskChildrenTaskLog.area_code.in_(user_area_codes)).all()
  496. # task_area_code_list = [i.area_code for i in tasklog]
  497. query_2 = db.query(RiskManagementInspectionUser).\
  498. filter(RiskManagementInspectionUser.del_flag!='2').\
  499. filter(RiskManagementInspectionUser.user_id==user_id)
  500. if task.task_range == '0':
  501. user_range_area_codes= ['440900000000']
  502. elif task.task_range == '1':
  503. query_2 = query_2.filter(
  504. and_(RiskManagementInspectionUser.area_code.like('%000000'),
  505. RiskManagementInspectionUser.area_code.notlike('%00000000')))
  506. user_range_area_codes= list({i.area_code for i in query_2.all()})
  507. elif task.task_range == '2':
  508. query_2 = query_2.filter(and_(RiskManagementInspectionUser.area_code.like('%000'),
  509. RiskManagementInspectionUser.area_code.notlike('%000000')))
  510. user_range_area_codes= list({i.area_code for i in query_2.all()})
  511. elif task.task_range == '3':
  512. query_2 = query_2.filter(RiskManagementInspectionUser.area_code.notlike('%000'))
  513. user_range_area_codes= list({i.area_code for i in query_2.all()})
  514. else:
  515. user_range_area_codes= []
  516. print(task.task_range)
  517. print(user_range_area_codes)
  518. for area_code in user_range_area_codes:
  519. tasklog = db.query(RiskManagementRiskTaskChildrenTaskLog). \
  520. filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2'). \
  521. filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id == task.id). \
  522. filter(RiskManagementRiskTaskChildrenTaskLog.area_code==area_code).first()
  523. task_info = {
  524. "id": task.id,
  525. "type": task.type,
  526. "cycle": task.cycle,
  527. "area_code":area_code,
  528. "area": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
  529. "task_status": tasklog is not None,
  530. "task_time": task.tsak_time.strftime('%Y-%m-%d'),
  531. "create_time": task.create_time.strftime('%Y-%m-%d %H:%M')
  532. }
  533. if tasklog :
  534. task_info['create_time'] = tasklog.create_time.strftime('%Y-%m-%d %H:%M')
  535. if task.tsak_time<datetime.today() and data['status']<1:
  536. data['status'] = 1 #有事已完成
  537. # elif tasklog.tsak_time > datetime.today():
  538. # data['status'] = 3 # 未来有事
  539. else:
  540. if task.tsak_time < datetime.today() and data['status'] < 2:
  541. data['status'] = 2 # 有事未完成
  542. elif task.tsak_time > datetime.today():
  543. data['status'] = 3 # 未来有事
  544. InspectionTasks_list.append(task_info)
  545. data['task_list']=InspectionTasks_list
  546. result.append(data)
  547. # 返回结果
  548. return {
  549. "code": 200,
  550. "msg": "成功",
  551. "data": result
  552. }
  553. except Exception as e:
  554. # 处理异常
  555. traceback.print_exc()
  556. raise HTTPException(status_code=500, detail=str(e))
  557. @router.get('/children/task/records')
  558. async def get_children_task_records_list(
  559. type: str =Query(None, description='类型'),
  560. page: int = Query(1, gt=0, description='页码'),
  561. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  562. db: Session = Depends(get_db),
  563. user_id = Depends(valid_access_token)
  564. ):
  565. try:
  566. # 获取子任务id
  567. query = db.query(RiskManagementRiskTaskChildrenTask)
  568. query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
  569. if type:
  570. query = query.filter(RiskManagementRiskTaskChildrenTask.type==type)
  571. children_ids = [i.id for i in query.all()]
  572. print(children_ids)
  573. # 构建查询
  574. query = db.query(RiskManagementRiskTaskChildrenTaskLog)
  575. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2')
  576. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.user_id == user_id)
  577. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id.in_(children_ids))
  578. total_items = query.count()
  579. # 排序
  580. query = query.order_by(RiskManagementRiskTaskChildrenTaskLog.create_time.desc())
  581. # 执行分页查询
  582. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  583. # 将查询结果转换为列表形式的字典
  584. InspectionTasks_list = []
  585. for task in InspectionTasks:
  586. children_task = risk_task_children_task_id_get_risk_task_children_task_info(db,task.children_task_id)
  587. task_info = {
  588. "id": task.children_task_id,
  589. "type": children_task.type,
  590. "task_range": children_task.task_range,
  591. "cycle": children_task.cycle,
  592. "area_code": task.area_code,
  593. "area": area_code_get_ancestors_names(db, area_code_get_area_info(db, task.area_code)),
  594. "task_time": children_task.tsak_time.strftime('%Y-%m-%d'),
  595. "create_time": task.create_time.strftime('%Y-%m-%d %H:%M')
  596. }
  597. InspectionTasks_list.append(task_info)
  598. # 返回结果
  599. return {
  600. "code": 200,
  601. "msg": "成功",
  602. "data": InspectionTasks_list,
  603. "total": total_items,
  604. "page": page,
  605. "pageSize": pageSize,
  606. "totalPages": (total_items + pageSize - 1) // pageSize
  607. }
  608. except Exception as e:
  609. # 处理异常
  610. traceback.print_exc()
  611. raise HTTPException(status_code=500, detail=str(e))
  612. @router.get('/children/task/result/{children_task_id}')
  613. async def get_children_task_result(
  614. children_task_id: str ,
  615. db: Session = Depends(get_db),
  616. page: int = Query(1, gt=0, description='页码'),
  617. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  618. user_id = Depends(valid_access_token)
  619. ):
  620. try:
  621. # 构建查询
  622. query = db.query(RiskManagementRiskTaskChildrenTaskResult)
  623. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.del_flag != '2')
  624. # 应用查询条件
  625. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.children_task_id == children_task_id)
  626. # 计算总条目数
  627. total_items = query.count()
  628. # 排序
  629. query = query.order_by(RiskManagementRiskTaskChildrenTaskResult.create_time.desc())
  630. # 执行分页查询
  631. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  632. InspectionTasks_list = []
  633. for task in InspectionTasks:
  634. area_code = task.area_code
  635. area = area_code_get_area_info(db, area_code)
  636. area = area_code_get_ancestors_names(db, area)
  637. task_info = {
  638. "id": task.id,
  639. # "children_task_id": task.children_task_id,
  640. "type":risk_task_children_task_id_get_risk_task_children_task_info(db,task.children_task_id).type,
  641. "point_name": task.inspection_point_name,
  642. # "area": area,
  643. # "create_time": task.create_time.strftime('%Y-%m-%d'),
  644. # "nick_name": task.nick_name,
  645. "task_result": task.inspection_result,
  646. "remark": task.remark,
  647. "fileList": get_file_query_fun(db=db, from_scenario='RiskManagementRiskTaskChildrenTaskResult',
  648. foreign_key=task.id)
  649. }
  650. InspectionTasks_list.append(task_info)
  651. # 返回结果
  652. return {
  653. "code": 200,
  654. "msg": "成功",
  655. "data": InspectionTasks_list,
  656. "total": total_items,
  657. "page": page,
  658. "pageSize": pageSize,
  659. "totalPages": (total_items + pageSize - 1) // pageSize
  660. }
  661. except Exception as e:
  662. # 处理异常
  663. traceback.print_exc()
  664. raise HTTPException(status_code=500, detail=str(e))
  665. @router.post('/children/task/result/create')
  666. async def create_inspection_task(
  667. db: Session = Depends(get_db),
  668. body = Depends(remove_xss_json),
  669. user_id = Depends(valid_access_token)
  670. ):
  671. try:
  672. children_task_id = body['children_task_id']
  673. result = body['result']
  674. area_code = body['area_code']
  675. area =area_code_get_ancestors_names(db, area_code_get_area_info(db, area_code))
  676. # task_time = body['task_time']
  677. # 创建新的
  678. new_task_log = RiskManagementRiskTaskChildrenTaskLog(
  679. id=new_guid(),
  680. children_task_id=children_task_id,
  681. area_code = area_code,
  682. area = area,
  683. task_status = '1',
  684. user_id = user_id,
  685. nick_name = user_id_get_user_info(db,user_id).nick_name,
  686. create_by = user_id
  687. )
  688. for info in result:
  689. new_file_list = info['fileList']
  690. inspection_point_name= info['point_name']
  691. inspection_result = info['task_result']
  692. remark = info['remark']
  693. new_task_result = RiskManagementRiskTaskChildrenTaskResult(
  694. id=new_guid(),
  695. children_task_id=children_task_id,
  696. inspection_point_name=inspection_point_name,
  697. area_code=area_code,
  698. inspection_result=inspection_result,
  699. remark = remark,
  700. user_id = user_id,
  701. nick_name = user_id_get_user_info(db,user_id).nick_name,
  702. create_by = user_id
  703. )
  704. db.add(new_task_result)
  705. for file in new_file_list:
  706. file_name = file['file_name']
  707. file_name_desc = file['file_name_desc']
  708. status = file['status']
  709. new_file = RiskManagementFile(
  710. file_id=new_guid(),
  711. foreign_key=new_task_result.id,
  712. from_scenario='RiskManagementRiskTaskChildrenTaskResult',
  713. file_name=file_name,
  714. file_name_desc=file_name_desc,
  715. status=status
  716. )
  717. db.add(new_file)
  718. # 添加到数据库会话并提交
  719. db.add(new_task_log)
  720. db.commit()
  721. # 标记消息已读
  722. child_task_info = db.query(RiskManagementRiskTaskChildrenTask).filter(RiskManagementRiskTaskChildrenTask.id == children_task_id).first()
  723. if child_task_info is not None:
  724. logger.info("标记[风险排查任务]已读 {}", str(child_task_info.task_id))
  725. db_msg_center.update_msg_read(db, user_id, "风险排查", str(child_task_info.task_id))
  726. # 返回创建成功的响应
  727. return {
  728. "code": 200,
  729. "msg": "成功",
  730. "data": None
  731. }
  732. except Exception as e:
  733. # 处理异常
  734. traceback.print_exc()
  735. raise HTTPException(status_code=500, detail=str(e))
  736. ####中屏子任务
  737. @router.get('/children/task/{task_id}/list')
  738. async def get_inspection_task_list(
  739. task_id: str ,
  740. page: int = Query(1, gt=0, description='页码'),
  741. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  742. db: Session = Depends(get_db),
  743. user_id = Depends(valid_access_token)
  744. ):
  745. try:
  746. # 构建查询
  747. query = db.query(RiskManagementRiskTaskChildrenTask)
  748. query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
  749. # 应用查询条件
  750. query = query.filter(RiskManagementRiskTaskChildrenTask.task_id == task_id)
  751. # 计算总条目数
  752. total_items = query.count()
  753. # 排序
  754. query = query.order_by(RiskManagementRiskTaskChildrenTask.tsak_time.asc())
  755. # 执行分页查询
  756. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  757. # 将查询结果转换为列表形式的字典
  758. InspectionTasks_list = []
  759. for task in InspectionTasks:
  760. task_num=task.task_num
  761. completed_num = db.query(RiskManagementRiskTaskChildrenTaskLog)\
  762. .filter(RiskManagementRiskTaskChildrenTaskLog.del_flag!='2')\
  763. .filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id==task.id).count()
  764. incomplete_num = task_num-completed_num
  765. task_info = {
  766. "id": task.id,
  767. "task_id":task.task_id,
  768. "task_number": task.task_number,
  769. "type": task.type,
  770. "task_time": task.tsak_time.strftime('%Y-%m-%d'),
  771. "cycle": task.cycle,
  772. "task_range": task.task_range,
  773. "completed_num": completed_num,
  774. "incomplete_num": incomplete_num,
  775. "create_time": task.create_time.strftime('%Y-%m-%d')
  776. }
  777. InspectionTasks_list.append(task_info)
  778. # 返回结果
  779. return {
  780. "code": 200,
  781. "msg": "成功",
  782. "data": InspectionTasks_list,
  783. "total": total_items,
  784. "page": page,
  785. "pageSize": pageSize,
  786. "totalPages": (total_items + pageSize - 1) // pageSize
  787. }
  788. except Exception as e:
  789. # 处理异常
  790. traceback.print_exc()
  791. raise HTTPException(status_code=500, detail=str(e))
  792. @router.get('/children/task/log/{children_task_id}/{status}/export')
  793. async def get_inspection_task_list(
  794. request: Request,
  795. children_task_id: str ,
  796. status:str,
  797. area_code: str = Query(None, description='区划编码'),
  798. db: Session = Depends(get_db),
  799. user_id = Depends(valid_access_token),
  800. auth_user: AuthUser = Depends(find_auth_user),
  801. ):
  802. try:
  803. # 构建查询
  804. total_items= 0
  805. InspectionTasks_list = []
  806. status_cn = ''
  807. if status == 'completed':
  808. status_cn='已完成'
  809. query = db.query(RiskManagementRiskTaskChildrenTaskLog)
  810. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2')
  811. # 应用查询条件
  812. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id == children_task_id)
  813. if area_code:
  814. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.area_code == area_code)
  815. # 计算总条目数
  816. total_items = query.count()
  817. # 排序
  818. query = query.order_by(RiskManagementRiskTaskChildrenTaskLog.create_time.desc())
  819. # 执行分页查询
  820. InspectionTasks = query.all()
  821. # 将查询结果转换为列表形式的字典
  822. for task in InspectionTasks:
  823. task_info = {
  824. "id": task.id,
  825. "子任务表id":children_task_id,
  826. "区划编码": task.area_code,
  827. "区划": task.area,
  828. "任务进展": '已完成',
  829. "排查人员id": task.user_id,
  830. "排查人员": task.nick_name,
  831. "创建时间": task.create_time.strftime('%Y-%m-%d')
  832. }
  833. InspectionTasks_list.append(task_info)
  834. # 返回结果
  835. elif status == 'incomplete':
  836. status_cn='未完成'
  837. children_task = risk_task_children_task_id_get_risk_task_children_task_info(db, children_task_id)
  838. if children_task:
  839. task = risk_task_id_get_risk_task_info(db, children_task.task_id)
  840. if task:
  841. complete_area_code_list = [i.area_code for i in
  842. risk_task_children_task_id_get_risk_task_children_task_log_info(db,
  843. children_task_id)]
  844. area_code_list = get_area_code_exclude_list(db, task.task_range, complete_area_code_list)
  845. if area_code:
  846. area_code_list = area_code_rang_get_area_children_list(db, children_task.task_range, area_code,
  847. complete_area_code_list)
  848. for area_code in area_code_list:
  849. task_info = {
  850. "id": new_guid(),
  851. "子任务表id": children_task_id,
  852. "区划编码": area_code,
  853. "区划": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
  854. "任务进展": '未完成',
  855. "排查人员id": '',
  856. "排查人员": '',
  857. "创建时间": children_task.tsak_time.strftime('%Y-%m-%d')
  858. }
  859. InspectionTasks_list.append(task_info)
  860. import pandas as pd
  861. from io import BytesIO
  862. # 将查询结果转换为 DataFrame
  863. df = pd.DataFrame(InspectionTasks_list)
  864. # 将 DataFrame 导出为 Excel 文件
  865. output = BytesIO()
  866. with pd.ExcelWriter(output, engine='openpyxl') as writer:
  867. df.to_excel(writer, index=False)
  868. # 设置响应头
  869. output.seek(0)
  870. from urllib.parse import quote
  871. encoded_filename = f'风险排查任务{status_cn}{datetime.now().strftime("%Y%m%d%H%mi%s")}.xlsx'
  872. encoded_filename = quote(encoded_filename, encoding='utf-8')
  873. headers = {
  874. 'Content-Disposition': f'attachment; filename*=UTF-8\'\'{encoded_filename}',
  875. 'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  876. }
  877. db_czrz.log(db, auth_user, "风险排查工作管理", f"风险排查任务{status_cn}导出数据成功", request.client.host)
  878. # 返回文件流
  879. return StreamingResponse(output, headers=headers)
  880. except Exception as e:
  881. traceback.print_exc()
  882. return JSONResponse(status_code=500, content={"code": 500, "msg": f"Internal server error: {str(e)}"})
  883. @router.get('/children/task/log/{children_task_id}/{status}/list')
  884. async def get_inspection_task_list(
  885. children_task_id: str ,
  886. status:str,
  887. area_code: str = Query(None, description='区划编码'),
  888. page: int = Query(1, gt=0, description='页码'),
  889. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  890. db: Session = Depends(get_db),
  891. user_id = Depends(valid_access_token)
  892. ):
  893. try:
  894. # 构建查询
  895. total_items= 0
  896. InspectionTasks_list = []
  897. if status=='completed':
  898. query = db.query(RiskManagementRiskTaskChildrenTaskLog)
  899. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2')
  900. # 应用查询条件
  901. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id == children_task_id)
  902. if area_code:
  903. query = query.filter(RiskManagementRiskTaskChildrenTaskLog.area_code == area_code)
  904. # 计算总条目数
  905. total_items = query.count()
  906. # 排序
  907. query = query.order_by(RiskManagementRiskTaskChildrenTaskLog.create_time.desc())
  908. # 执行分页查询
  909. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  910. # 将查询结果转换为列表形式的字典
  911. for task in InspectionTasks:
  912. task_info = {
  913. "id": task.id,
  914. "children_task_id":children_task_id,
  915. "area_code": task.area_code,
  916. "area": task.area,
  917. "task_status": task.task_status,
  918. "user_id": task.user_id,
  919. "nick_name": task.nick_name,
  920. "create_time": task.create_time.strftime('%Y-%m-%d')
  921. }
  922. InspectionTasks_list.append(task_info)
  923. # 返回结果
  924. elif status == 'incomplete':
  925. children_task = risk_task_children_task_id_get_risk_task_children_task_info(db,children_task_id)
  926. if children_task:
  927. task = risk_task_id_get_risk_task_info(db,children_task.task_id)
  928. if task:
  929. complete_area_code_list =[i.area_code for i in risk_task_children_task_id_get_risk_task_children_task_log_info(db,children_task_id)]
  930. area_code_list = get_area_code_exclude_list(db,task.task_range,complete_area_code_list)
  931. if area_code:
  932. area_code_list = area_code_rang_get_area_children_list(db, children_task.task_range, area_code,
  933. complete_area_code_list)
  934. for area_code in area_code_list:
  935. task_info = {
  936. "id": new_guid(),
  937. "children_task_id": children_task_id,
  938. "area_code": area_code,
  939. "area": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
  940. "task_status": '0',
  941. "user_id": '',
  942. "nick_name": '',
  943. "create_time": children_task.tsak_time.strftime('%Y-%m-%d')
  944. }
  945. InspectionTasks_list.append(task_info)
  946. return {
  947. "code": 200,
  948. "msg": "成功",
  949. "data": InspectionTasks_list,
  950. "total": total_items,
  951. "page": page,
  952. "pageSize": pageSize,
  953. "totalPages": (total_items + pageSize - 1) // pageSize
  954. }
  955. except Exception as e:
  956. # 处理异常
  957. traceback.print_exc()
  958. raise HTTPException(status_code=500, detail=str(e))
  959. @router.get('/children/task/result/{children_task_id}/list')
  960. async def get_inspection_task_list(
  961. children_task_id: str ,
  962. area_code: str = Query(None, description='区划编码'),
  963. result: str = Query(None, description='巡查结果'),
  964. nick_name: str = Query(None, description='姓名'),
  965. page: int = Query(1, gt=0, description='页码'),
  966. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  967. db: Session = Depends(get_db),
  968. user_id = Depends(valid_access_token)
  969. ):
  970. try:
  971. # 构建查询
  972. query = db.query(RiskManagementRiskTaskChildrenTaskResult)
  973. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.del_flag != '2')
  974. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.children_task_id == children_task_id)
  975. # 应用查询条件
  976. if area_code:
  977. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.area_code == area_code)
  978. if result:
  979. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.inspection_result == result)
  980. if nick_name:
  981. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.nick_name.like(f'%{nick_name}%') )
  982. # 计算总条目数
  983. total_items = query.count()
  984. # 排序
  985. query = query.order_by(RiskManagementRiskTaskChildrenTaskResult.create_time.desc())
  986. # 执行分页查询
  987. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  988. # 将查询结果转换为列表形式的字典
  989. InspectionTasks_list = []
  990. for task in InspectionTasks:
  991. area_code = task.area_code
  992. area = area_code_get_area_info(db, area_code)
  993. area = area_code_get_ancestors_names(db, area)
  994. task_info = {
  995. "id": task.id,
  996. "children_task_id": task.children_task_id,
  997. "point_name":task.inspection_point_name,
  998. "area": area,
  999. "create_time": task.create_time.strftime('%Y-%m-%d'),
  1000. "nick_name": task.nick_name,
  1001. "result": task.inspection_result,
  1002. "fileList": get_file_query_fun(db=db,from_scenario='RiskManagementRiskTaskChildrenTaskResult', foreign_key=task.id),
  1003. "remark":task.remark
  1004. }
  1005. InspectionTasks_list.append(task_info)
  1006. # 返回结果
  1007. return {
  1008. "code": 200,
  1009. "msg": "成功",
  1010. "data": InspectionTasks_list,
  1011. "total": total_items,
  1012. "page": page,
  1013. "pageSize": pageSize,
  1014. "totalPages": (total_items + pageSize - 1) // pageSize
  1015. }
  1016. except Exception as e:
  1017. # 处理异常
  1018. traceback.print_exc()
  1019. raise HTTPException(status_code=500, detail=str(e))
  1020. @router.get('/children/task/result/{children_task_id}/export')
  1021. async def get_inspection_task_list(
  1022. request: Request,
  1023. children_task_id: str ,
  1024. area_code: str = Query(None, description='区划编码'),
  1025. result: str = Query(None, description='巡查结果'),
  1026. nick_name: str = Query(None, description='姓名'),
  1027. page: int = Query(1, gt=0, description='页码'),
  1028. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  1029. auth_user: AuthUser = Depends(find_auth_user),
  1030. db: Session = Depends(get_db),
  1031. user_id = Depends(valid_access_token)
  1032. ):
  1033. try:
  1034. # 构建查询
  1035. query = db.query(RiskManagementRiskTaskChildrenTaskResult)
  1036. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.del_flag != '2')
  1037. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.children_task_id == children_task_id)
  1038. # 应用查询条件
  1039. if area_code:
  1040. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.area_code == area_code)
  1041. if result:
  1042. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.inspection_result == result)
  1043. if nick_name:
  1044. query = query.filter(RiskManagementRiskTaskChildrenTaskResult.nick_name.like(f'%{nick_name}%') )
  1045. # 计算总条目数
  1046. total_items = query.count()
  1047. # 排序
  1048. query = query.order_by(RiskManagementRiskTaskChildrenTaskResult.create_time.desc())
  1049. # 执行分页查询
  1050. InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
  1051. # 将查询结果转换为列表形式的字典
  1052. InspectionTasks_list = []
  1053. for task in InspectionTasks:
  1054. area_code = task.area_code
  1055. area = area_code_get_area_info(db, area_code)
  1056. area = area_code_get_ancestors_names(db, area)
  1057. task_info = {
  1058. "id": task.id,
  1059. "子任务表id": task.children_task_id,
  1060. "经度":task.longitude,
  1061. "纬度":task.latitude,
  1062. "巡查点":task.inspection_point_name,
  1063. "区划": area,
  1064. "创建时间": task.create_time.strftime('%Y-%m-%d'),
  1065. "采集人员": task.nick_name,
  1066. "采集结果": task.inspection_result,
  1067. # "fileList": get_file_query_fun(db=db,from_scenario='RiskManagementRiskTaskChildrenTaskResult', foreign_key=task.id),
  1068. "备注":task.remark
  1069. }
  1070. InspectionTasks_list.append(task_info)
  1071. # 返回结果
  1072. import pandas as pd
  1073. from io import BytesIO
  1074. # 将查询结果转换为 DataFrame
  1075. df = pd.DataFrame(InspectionTasks_list)
  1076. # 将 DataFrame 导出为 Excel 文件
  1077. output = BytesIO()
  1078. with pd.ExcelWriter(output, engine='openpyxl') as writer:
  1079. df.to_excel(writer, index=False)
  1080. # 设置响应头
  1081. output.seek(0)
  1082. from urllib.parse import quote
  1083. encoded_filename = f'救援资源要素巡查结果{datetime.now().strftime("%Y%m%d%H%mi%s")}.xlsx'
  1084. encoded_filename = quote(encoded_filename, encoding='utf-8')
  1085. headers = {
  1086. 'Content-Disposition': f'attachment; filename*=UTF-8\'\'{encoded_filename}',
  1087. 'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  1088. }
  1089. db_czrz.log(db, auth_user, "救援资源要素管理", f"救援资源要素巡查结果导出数据成功", request.client.host)
  1090. # 返回文件流
  1091. return StreamingResponse(output, headers=headers)
  1092. except Exception as e:
  1093. # 处理异常
  1094. traceback.print_exc()
  1095. return JSONResponse(status_code=500, content={"code": 500, "msg": f"Internal server error: {str(e)}"})