main.py 35 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171
  1. import xml.etree.ElementTree as ET
  2. from typing import Union, Annotated
  3. from fastapi import FastAPI, HTTPException, status, Depends
  4. import os
  5. import uuid
  6. import re
  7. import zipfile
  8. import json
  9. import chromadb
  10. from datetime import timedelta
  11. from fastapi.middleware.cors import CORSMiddleware
  12. from fastapi.middleware.gzip import GZipMiddleware
  13. from sentence_transformers import SentenceTransformer
  14. model = SentenceTransformer("BAAI/bge-small-zh-v1.5")
  15. import base64
  16. from pydantic import BaseModel
  17. from subdir import service
  18. from subdir import db
  19. from subdir import util
  20. import xml.dom.minidom as MD
  21. import numpy as np
  22. from fastapi.staticfiles import StaticFiles
  23. import httpx
  24. httpClient = httpx.AsyncClient()
  25. from pymongo import AsyncMongoClient
  26. uri = "mongodb://owner:Pheecian1@47.101.198.30:27017/baojia"
  27. uri2 = "mongodb://owner:Pheecian1@47.101.198.30:27017/dinge"
  28. client = AsyncMongoClient(uri)
  29. dingeclient = AsyncMongoClient(uri2)
  30. chroma_client = chromadb.HttpClient(host='47.101.198.30', port=8000)
  31. from fastapi.responses import FileResponse, RedirectResponse
  32. from fastapi_cache import FastAPICache
  33. from inmemory import InMemoryBackend
  34. from fastapi_cache.decorator import cache
  35. from contextlib import asynccontextmanager
  36. from fastapi import WebSocket, WebSocketDisconnect
  37. from fastapi import UploadFile, File, Form
  38. from collections.abc import AsyncIterator
  39. from tasks import process_data
  40. from celery.result import AsyncResult
  41. from fastapi_login import LoginManager
  42. class ConnectionManager:
  43. """Class defining socket events"""
  44. def __init__(self):
  45. """init method, keeping track of connections"""
  46. self.active_connections = []
  47. async def connect(self, websocket: WebSocket):
  48. """connect event"""
  49. await websocket.accept()
  50. self.active_connections.append(websocket)
  51. async def send_personal_message(self, message: str, websocket: WebSocket):
  52. """Direct Message"""
  53. await websocket.send_text(message)
  54. def disconnect(self, websocket: WebSocket):
  55. """disconnect event"""
  56. self.active_connections.remove(websocket)
  57. @asynccontextmanager
  58. async def lifespan(_: FastAPI) -> AsyncIterator[None]:
  59. FastAPICache.init(InMemoryBackend(), prefix="default")
  60. yield
  61. SECRET = '400687251779e65aca22ef5bb52b9cc4c218c63571004aeb'
  62. app = FastAPI(lifespan=lifespan)
  63. origins = [
  64. "http://localhost.tiangolo.com",
  65. "https://localhost.tiangolo.com",
  66. "http://localhost",
  67. "http://localhost:9002",
  68. "http://127.0.0.1:9002",
  69. ]
  70. app.add_middleware(
  71. CORSMiddleware,
  72. allow_origins=["*"],
  73. allow_credentials=True,
  74. allow_methods=["*"],
  75. allow_headers=["*"],
  76. )
  77. ##app.add_middleware(GZipMiddleware, minimum_size=1000, compresslevel=5)
  78. ##app.mount("/static", StaticFiles(directory="front/dist"), name="static")
  79. ##manager = ConnectionManager()
  80. manager = LoginManager(SECRET, token_url='/token')
  81. @manager.user_loader()
  82. def load_user(id: str): # could also be an asynchronous function
  83. return id
  84. class Task(BaseModel):
  85. bianma: str
  86. mc: str
  87. tz: str
  88. dw: str
  89. sl: str
  90. n: int
  91. label: str
  92. class Jxtz(BaseModel):
  93. biao_id: str
  94. bh: str
  95. glf: str
  96. lr: str
  97. bz: int
  98. gong: str
  99. chaiyou: str
  100. qiyou: str
  101. dian: str
  102. class Xxj(BaseModel):
  103. city: str
  104. month: str
  105. class Rgtz(BaseModel):
  106. biao_id: str
  107. bh: str
  108. yi: str
  109. er: str
  110. san: str
  111. glf: str
  112. lr: str
  113. bz: int
  114. class Zcfx(BaseModel):
  115. biao_id: str
  116. bh: str
  117. class Zcfx2(BaseModel):
  118. biao_id: str
  119. bh: str
  120. prefix: str
  121. class Info(BaseModel):
  122. name: str
  123. class DingeshuRequest(BaseModel):
  124. value: int
  125. class DingeXilieRequest(BaseModel):
  126. value: int
  127. id: str
  128. class SingleDingeXilieRequest(BaseModel):
  129. zhuanye: int
  130. debh: str
  131. class InfoWithID(BaseModel):
  132. name: str
  133. id: str
  134. class Tiaojia(BaseModel):
  135. biao_id: str
  136. bh: str
  137. bm: str
  138. mingcheng: str
  139. danwei: str
  140. jiage: str
  141. glf: str
  142. lr: str
  143. bz: int
  144. class SearchDe(BaseModel):
  145. zhuanye: str
  146. text: str
  147. class UpdateZjcs(BaseModel):
  148. biao_id: str
  149. bh: str
  150. mc: str
  151. fl: str
  152. class Item(BaseModel):
  153. bh: str
  154. bt: str
  155. name: str
  156. class Rcj(BaseModel):
  157. bh: str
  158. bt: str
  159. bm: str
  160. name: str
  161. class Dercj(BaseModel):
  162. bh: str
  163. bt: str
  164. qdbm: str
  165. debm: str
  166. name: str
  167. class Zjcs(BaseModel):
  168. bh: str
  169. name: str
  170. @app.post("/pushtask/")
  171. async def pushtask(r: Task, user=Depends(manager)):
  172. task = process_data.apply_async(kwargs={"data": {"bianma": r.bianma, "mc": r.mc, "tz": r.tz, "dw": r.dw, "sl": r.sl, "n": r.n, "label": r.label}})
  173. return {"id": task.id}
  174. @app.get("/checktask/{id}")
  175. async def checktask(id, user=Depends(manager)):
  176. print(id)
  177. result = AsyncResult(id)
  178. return {
  179. "status": result.status,
  180. "result": result.result if result.ready() else None
  181. }
  182. @app.post("/outline2")
  183. async def read_root2(info: Info, user=Depends(manager)):
  184. return await db.getOutline(client, info.name, user)
  185. @app.post("/detail2")
  186. async def read_detail2(info: Info, user=Depends(manager)):
  187. return await db.getDetail(client, info.name, user)
  188. @app.post("/baojiahuizong2/")
  189. async def read_bjhz2(info: InfoWithID, user=Depends(manager)):
  190. raw = await db.getBjhz(client, info.name, info.id)
  191. raw2 = []
  192. for entry in raw:
  193. if "__children" in entry:
  194. entry["_children"] = entry["__children"]
  195. for grandchild in entry["_children"]:
  196. if "__children" in grandchild:
  197. grandchild['_children'] = grandchild['__children']
  198. del grandchild['__children']
  199. del entry["__children"]
  200. raw2.append(entry)
  201. return raw2
  202. @app.post("/guifeishuijin2/")
  203. async def read_gfsj2(info: InfoWithID, user=Depends(manager)):
  204. raw = await db.getGfsj(client, info.name, info.id)
  205. raw2 = []
  206. for entry in raw:
  207. if "__children" in entry:
  208. entry["_children"] = entry["__children"]
  209. del entry["__children"]
  210. raw2.append(entry)
  211. return raw2
  212. @app.post("/qitaxiangmu2/")
  213. async def read_qtxm2(info: InfoWithID, user=Depends(manager)):
  214. raw = await db.getQtxm(client, info.name, info.id)
  215. raw2 = []
  216. for entry in raw:
  217. if "__children" in entry:
  218. entry["_children"] = entry["__children"]
  219. del entry["__children"]
  220. raw2.append(entry)
  221. return raw2
  222. @app.post("/zygczgj/")
  223. async def zygczgj(info: InfoWithID, user=Depends(manager)):
  224. return await db.getZygczgj(client, info.name, info.id)
  225. @app.post("/zanliejine2/")
  226. async def read_zlje2(info: InfoWithID, user=Depends(manager)):
  227. return await db.getZlje(client, info.name, info.id)
  228. @app.post("/jirigong2/")
  229. async def read_jrg2(info: InfoWithID, user=Depends(manager)):
  230. return await db.getJrg(client, info.name, info.id)
  231. @app.post("/zongchengbaofuwufei2/")
  232. async def read_zcbfwf2(info: InfoWithID, user=Depends(manager)):
  233. return await db.getZcbfwf(client, info.name, info.id)
  234. @app.post("/fabaorengongyingcailiao2/")
  235. async def read_fbrgycl2(info: InfoWithID, user=Depends(manager)):
  236. return await db.getFbrgycl(client, info.name, info.id)
  237. @app.post("/rencaijihuizong2/")
  238. async def read_rcjhz2(info: InfoWithID, user=Depends(manager)):
  239. return await db.getRcjhz(client, info.name, info.id)
  240. @app.post("/qingdanxiangmu2/")
  241. async def read_qdxm2(info: InfoWithID, user=Depends(manager)):
  242. return await db.getQdxm(client, info.name, info.id)
  243. @app.post("/qingdanmingxi/")
  244. async def read_qdmx(item : Item, user=Depends(manager)):
  245. return await db.getQdmx(client, item.name, item.bh, item.bt)
  246. @app.get("/qingdantuijian/{bm}")
  247. @cache(expire=86400)
  248. async def read_tuijian(bm: str):
  249. return service.getQingdanTuijian("", "", bm)
  250. @app.post("/zjcs/")
  251. async def read_zjcs(item : Zjcs, user=Depends(manager)):
  252. raw = await db.getZjcs(client, item.name, item.bh)
  253. raw2 = []
  254. for entry in raw:
  255. if "__children" in entry:
  256. entry["_children"] = entry["__children"]
  257. del entry["__children"]
  258. raw2.append(entry)
  259. return raw2
  260. @app.post("/djcs/")
  261. async def read_djcs(item : Zjcs, user=Depends(manager)):
  262. raw = await db.getDjcs(client, item.name, item.bh)
  263. raw2 = []
  264. for entry in raw:
  265. if "__children" in entry:
  266. entry["_children"] = entry["__children"]
  267. del entry["__children"]
  268. raw2.append(entry)
  269. return raw2
  270. @app.post("/files2/")
  271. async def read_files2(user=Depends(manager)):
  272. result = await db.list_files(client, user)
  273. return result
  274. @app.post("/deleteFile/")
  275. async def delete(r: Info, user=Depends(manager)):
  276. result = await db.delete_files(client, r.name, user)
  277. return result
  278. @app.get("/qingdanshu/{zhuanye}")
  279. @cache(expire=86400)
  280. async def read_qds(zhuanye : str):
  281. result = service.getQds()
  282. if zhuanye == '10':
  283. return [result[0]]
  284. elif zhuanye == '20':
  285. return [result[2]]
  286. elif zhuanye == '30':
  287. return [result[3]]
  288. elif zhuanye == '40':
  289. return [result[4]]
  290. else:
  291. return result
  292. @app.get("/qingdan/{bm}")
  293. @cache(expire=86400)
  294. async def read_qingdan(bm: str):
  295. result = service.getQingdan(bm)
  296. return result
  297. @app.get("/des/{value}")
  298. @cache(expire=86400)
  299. async def read_des(value: int):
  300. result = service.getDes(value)
  301. if value == 30:
  302. result.append({
  303. "id": "2075",
  304. "key" : "2075",
  305. "value" : "2075",
  306. "label" : "安装费用",
  307. "title" : "安装费用",
  308. "children" : [
  309. {
  310. "id": "2076",
  311. "key" : "2076",
  312. "value" : "2076",
  313. "label" : "脚手架搭拆费",
  314. "title" : "脚手架搭拆费",
  315. "children" : []
  316. },
  317. {
  318. "id": "2077",
  319. "key" : "2077",
  320. "value" : "2077",
  321. "label" : "施工超高增加费",
  322. "title" : "施工超高增加费",
  323. "children" : []
  324. },
  325. {
  326. "id": "2080",
  327. "key" : "2080",
  328. "value" : "2080",
  329. "label" : "高层建筑增加费",
  330. "title" : "高层建筑增加费",
  331. "children" : [
  332. {
  333. "id": "2081",
  334. "key" : "2081",
  335. "value" : "2081",
  336. "label" : "第四册",
  337. "title" : "第四册",
  338. "children" : []
  339. },
  340. {
  341. "id": "2082",
  342. "key" : "2082",
  343. "value" : "2082",
  344. "label" : "第五册",
  345. "title" : "第五册",
  346. "children" : []
  347. },
  348. {
  349. "id": "2083",
  350. "key" : "2083",
  351. "value" : "2083",
  352. "label" : "第七册",
  353. "title" : "第七册",
  354. "children" : []
  355. },
  356. {
  357. "id": "2084",
  358. "key" : "2084",
  359. "value" : "2084",
  360. "label" : "第九册",
  361. "title" : "第九册",
  362. "children" : []
  363. },
  364. {
  365. "id": "2085",
  366. "key" : "2085",
  367. "value" : "2085",
  368. "label" : "第十册",
  369. "title" : "第十册",
  370. "children" : []
  371. },
  372. {
  373. "id": "2086",
  374. "key" : "2086",
  375. "value" : "2086",
  376. "label" : "第十一册",
  377. "title" : "第十一册",
  378. "children" : []
  379. },
  380. ]
  381. },
  382. {
  383. "id": "2078",
  384. "key" : "2078",
  385. "value" : "2078",
  386. "label" : "安装生产同时增加费",
  387. "title" : "安装生产同时增加费",
  388. "children" : []
  389. },
  390. {
  391. "id": "2079",
  392. "key" : "2079",
  393. "value" : "2079",
  394. "label" : "有害环境操作增加费",
  395. "title" : "有害环境操作增加费",
  396. "children" : []
  397. },
  398. {
  399. "id": "2087",
  400. "key" : "2087",
  401. "value" : "2087",
  402. "label" : "系统调试费",
  403. "title" : "系统调试费",
  404. "children" : []
  405. },
  406. ]
  407. })
  408. if value == 60:
  409. result.append({
  410. "id": "184",
  411. "key" : "184",
  412. "value" : "184",
  413. "label" : "安装费用",
  414. "title" : "安装费用",
  415. "children" : [
  416. {
  417. "id": "185",
  418. "key" : "185",
  419. "value" : "185",
  420. "label" : "脚手架搭拆费",
  421. "title" : "脚手架搭拆费",
  422. "children" : []
  423. },
  424. {
  425. "id": "186",
  426. "key" : "186",
  427. "value" : "186",
  428. "label" : "施工超高增加费",
  429. "title" : "施工超高增加费",
  430. "children" : []
  431. },
  432. {
  433. "id": "187",
  434. "key" : "187",
  435. "value" : "187",
  436. "label" : "高层建筑增加费",
  437. "title" : "高层建筑增加费",
  438. "children" : []
  439. }
  440. ]
  441. })
  442. return result
  443. @app.get("/pbs/{value}")
  444. @cache(expire=86400)
  445. async def read_pbs(value:int):
  446. result = service.getPbs(value)
  447. #print(result)
  448. result.insert(0, {"id": "0","key": "0", "label": "全部", "title": "全部"})
  449. return result
  450. @app.get("/jxs/{value}")
  451. @cache(expire=86400)
  452. async def read_jxs(value:int):
  453. result = service.getJxs(value)
  454. #print(result)
  455. result.insert(0, {"id": "0","key": "0", "label": "全部", "title": "全部"})
  456. return result
  457. @app.get("/cls/{value}")
  458. @cache(expire=86400)
  459. async def read_cls(value:int):
  460. result = service.getCls(value)
  461. #print(result)
  462. result.insert(0, {"id": "0","key": "0", "label": "全部", "title": "全部"})
  463. return result
  464. @app.get("/pbxl/{name}/{zhuanye}")
  465. @cache(expire=86400)
  466. async def read_pbxl(name: str, zhuanye: int):
  467. result = service.getPbxl(name, zhuanye)
  468. #print(result)
  469. return result
  470. @app.get("/jxxl/{name}/{zhuanye}")
  471. @cache(expire=86400)
  472. async def read_jxxl(name: str, zhuanye: int):
  473. result = service.getJxxl(name, zhuanye)
  474. #print(result)
  475. return result
  476. @app.get("/clxl/{name}/{zhuanye}")
  477. @cache(expire=86400)
  478. async def read_clxl(name: str, zhuanye: int):
  479. result = service.getClxl(name, zhuanye)
  480. #print(result)
  481. return result
  482. @app.get("/cankao/")
  483. @cache(expire=86400)
  484. async def cankao():
  485. result = service.getCankao()
  486. #print(result)
  487. return result
  488. @app.post("/qufei/")
  489. async def read_qufei(r: Info, user=Depends(manager)):
  490. return await db.getQufei(client, r.name, user)
  491. @app.post("/jiagongcai/")
  492. async def read_jiagongcai(r: Info, user=Depends(manager)):
  493. return await db.getJiagongcai(client, r.name)
  494. @app.get("/dexilie/{value}/{id}")
  495. @cache(expire=86400)
  496. async def read_dexilie(value: int, id: str):
  497. if value == 30 and int(id) > 2074:
  498. return service.getDeXilie_azfy(value, id)
  499. if value == 60 and int(id) > 183:
  500. return service.getDeXilie_xsazfy(value, id)
  501. result = service.getDeXilie(value, id)
  502. #print(result)
  503. return result
  504. @app.get("/singledexilie2/{zhuanye}/{debh}")##debh = debh!description
  505. @cache(expire=86400)
  506. async def read_singledexilie2(zhuanye: int, debh: str):
  507. if debh.startswith("D") :
  508. return json.dumps({
  509. "reverse": "None",
  510. "rgde": None,
  511. "jxde": None,
  512. "clde": None,
  513. "actual_zhuanye": zhuanye,
  514. "bz_selected": {"BZBH": {}},
  515. "bz_selected2": {"BZBH": {}}
  516. }, ensure_ascii=False)
  517. if "-F" in debh and zhuanye == 30:
  518. return service.read_singledexilie_azfy(debh)
  519. if "-F" in debh and zhuanye == 60:
  520. return service.read_singledexilie_xsazfy(debh)
  521. if debh == '19-19':
  522. return service.read_singledexilie_tjazfy(debh)
  523. if debh == '19-20':
  524. return service.read_singledexilie_tjazfy(debh)
  525. if debh == '19-21':
  526. return service.read_singledexilie_tjazfy(debh)
  527. if debh == '19-22':
  528. return service.read_singledexilie_tjazfy(debh)
  529. if debh == '19-23':
  530. return service.read_singledexilie_tjazfy(debh)
  531. if debh == '19-24':
  532. return service.read_singledexilie_tjazfy(debh)
  533. if debh == '19-25':
  534. return service.read_singledexilie_tjazfy(debh)
  535. if debh == '19-26':
  536. return service.read_singledexilie_tjazfy(debh)
  537. if debh == '19-27':
  538. return service.read_singledexilie_tjazfy(debh)
  539. if debh == '19-28':
  540. return service.read_singledexilie_tjazfy(debh)
  541. if debh == '19-29':
  542. return service.read_singledexilie_tjazfy(debh)
  543. if debh == '19-30':
  544. return service.read_singledexilie_tjazfy(debh)
  545. if debh == '19-31':
  546. return service.read_singledexilie_tjazfy(debh)
  547. if debh == '19-32':
  548. return service.read_singledexilie_tjazfy(debh)
  549. if debh == '19-33':
  550. return service.read_singledexilie_tjazfy(debh)
  551. if debh == '19-34':
  552. return service.read_singledexilie_tjazfy(debh)
  553. if debh == '19-35':
  554. return service.read_singledexilie_tjazfy(debh)
  555. if debh == '19-36':
  556. return service.read_singledexilie_tjazfy(debh)
  557. r_debh = debh.split("!")[0]
  558. if "附注" in r_debh:
  559. position = r_debh.find("附注")
  560. r_debh = r_debh[:position]
  561. ##print(r_debh)
  562. result1, result2, rgde, jxde, clde, bz_selected, bz_selected2, actual_zhuanye= service.getSingleDeXilie(zhuanye, r_debh)
  563. ##print("get result ***************************************")
  564. if result1:
  565. result3 = json.loads(result1)
  566. else:
  567. result3 = {}
  568. result3["reverse"] = str(result2)
  569. result3["rgde"] = rgde
  570. result3["jxde"] = jxde
  571. result3["clde"] = clde
  572. result3["actual_zhuanye"] = actual_zhuanye
  573. if bz_selected != None:
  574. result3["bz_selected"] = json.loads(bz_selected)
  575. else:
  576. result3["bz_selected"] = {"BZBH": {}}
  577. if bz_selected2 != None:
  578. result3["bz_selected2"] = json.loads(bz_selected2)
  579. else:
  580. result3["bz_selected2"] = {"BZBH": {}}
  581. ####14-227+[14-228]*-2
  582. ####3-409*1.2
  583. ##print(r_debh)
  584. if "[" in r_debh:
  585. position3 = r_debh.find("*")
  586. coef = 1
  587. if position3 == -1:
  588. pass
  589. else:
  590. coef = r_debh[1 + position3:]
  591. ##print(coef)
  592. tail = 0
  593. for i in range(0, len(coef) + 1):
  594. if i == len(coef):
  595. tail = i
  596. break
  597. if (coef[i] > '9' or coef[i] < '0') and coef[i] != '-' and coef[i] != '.':
  598. tail = i
  599. break
  600. if tail == 0:
  601. ##print("1113111")
  602. result3["reverse"] = 'None'
  603. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  604. coef = float(coef[0:tail])
  605. position1 = r_debh.find("[")
  606. position2 = r_debh.find("]")
  607. if position2 == -1:
  608. ##print("1121111")
  609. result3["reverse"] = 'None'
  610. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  611. if r_debh[position1-1] == "+":
  612. pass
  613. elif r_debh[position1-1] == "-":
  614. coef = -coef
  615. else:
  616. ##print("111111")
  617. result3["reverse"] = 'None'
  618. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  619. debh = r_debh[position1+1: position2]
  620. if result3['GLDE']: ##csv文件里的字段,表示这个定额有没有配套的增减定额
  621. hit = False
  622. for key, value in result3['GLDE'].items():
  623. if debh in value:
  624. hit = True
  625. if not hit:
  626. result3["reverse"] = 'None'
  627. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  628. else:
  629. result3["reverse"] = 'None'
  630. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  631. result1_, result2_, rgde_, jxde_, clde_, bz_selected_, bz_selected2_, actual_zhuanye_ = service.getSingleDeXilie(zhuanye, debh)
  632. if result1_:
  633. rgde=util.mergerg(rgde, rgde_, coef)
  634. jxde=util.mergejx(jxde, jxde_, coef)
  635. clde=util.mergecl(clde, clde_, coef)
  636. result3["rgde"] = rgde
  637. result3["jxde"] = jxde
  638. result3["clde"] = clde
  639. item_ = None
  640. for item in result3['DW'].keys():
  641. item_ = item
  642. result3['DEBH'] = {item_: util.cleanBM(r_debh)}
  643. else:
  644. result3["reverse"] = 'None'
  645. elif "*" in r_debh:##1-234*1.2
  646. position3 = r_debh.find("*")
  647. coef = 1
  648. coef = r_debh[1 + position3:]
  649. ##print(coef)
  650. tail = 0
  651. for i in range(0, len(coef) + 1):
  652. if i == len(coef):
  653. tail = i
  654. break
  655. if (coef[i] > '9' or coef[i] < '0') and coef[i] != '-' and coef[i] != '.':
  656. tail = i
  657. break
  658. if tail == 0:
  659. ##print("1113111")
  660. result3["reverse"] = 'None'
  661. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  662. coef = float(coef[0:tail])
  663. util.multirg(result3["rgde"], coef)
  664. util.multijx(result3["jxde"], coef)
  665. util.multicl(result3["clde"], coef)
  666. item_ = None
  667. for item in result3['DW'].keys():
  668. item_ = item
  669. result3['DEBH'] = {item_: (r_debh)}
  670. ##print(result3)
  671. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  672. @app.get("/singledexilie/{zhuanye}/{debh}/{mc}")
  673. @cache(expire=86400)
  674. async def read_singledexilie(zhuanye: int, debh: str, mc: str):
  675. if debh.startswith("D") :
  676. return json.dumps({
  677. "reverse": "None",
  678. "rgde": None,
  679. "jxde": None,
  680. "clde": None,
  681. "actual_zhuanye": zhuanye,
  682. "bz_selected": {"BZBH": {}},
  683. "bz_selected2": {"BZBH": {}}
  684. }, ensure_ascii=False)
  685. if "-F" in debh:
  686. if mc == '第一章' or mc == '第二章' or mc == '第三章':
  687. return service.read_singledexilie_xsazfy(debh)
  688. return service.read_singledexilie_azfy(debh)
  689. if debh == '19-19':
  690. return service.read_singledexilie_tjazfy(debh)
  691. if debh == '19-20':
  692. return service.read_singledexilie_tjazfy(debh)
  693. if debh == '19-21':
  694. return service.read_singledexilie_tjazfy(debh)
  695. if debh == '19-22':
  696. return service.read_singledexilie_tjazfy(debh)
  697. if debh == '19-23':
  698. return service.read_singledexilie_tjazfy(debh)
  699. if debh == '19-24':
  700. return service.read_singledexilie_tjazfy(debh)
  701. if debh == '19-25':
  702. return service.read_singledexilie_tjazfy(debh)
  703. if debh == '19-26':
  704. return service.read_singledexilie_tjazfy(debh)
  705. if debh == '19-27':
  706. return service.read_singledexilie_tjazfy(debh)
  707. if debh == '19-28':
  708. return service.read_singledexilie_tjazfy(debh)
  709. if debh == '19-29':
  710. return service.read_singledexilie_tjazfy(debh)
  711. if debh == '19-30':
  712. return service.read_singledexilie_tjazfy(debh)
  713. if debh == '19-31':
  714. return service.read_singledexilie_tjazfy(debh)
  715. if debh == '19-32':
  716. return service.read_singledexilie_tjazfy(debh)
  717. if debh == '19-33':
  718. return service.read_singledexilie_tjazfy(debh)
  719. if debh == '19-34':
  720. return service.read_singledexilie_tjazfy(debh)
  721. if debh == '19-35':
  722. return service.read_singledexilie_tjazfy(debh)
  723. if debh == '19-36':
  724. return service.read_singledexilie_tjazfy(debh)
  725. r_debh = debh.split("!")[0]
  726. if "附注" in r_debh:
  727. position = r_debh.find("附注")
  728. r_debh = r_debh[:position]
  729. ##print(r_debh)
  730. result1, result2, rgde, jxde, clde, bz_selected, bz_selected2, actual_zhuanye= await db.getSingleDeXilie(model, dingeclient, zhuanye, r_debh, mc)
  731. ###print("get result ***************************************")
  732. if result1:
  733. result3 = json.loads(result1)
  734. else:
  735. result3 = {}
  736. result3["reverse"] = str(result2)
  737. result3["rgde"] = rgde
  738. result3["jxde"] = jxde
  739. result3["clde"] = clde
  740. result3["actual_zhuanye"] = actual_zhuanye
  741. if bz_selected != None:
  742. result3["bz_selected"] = json.loads(bz_selected)
  743. else:
  744. result3["bz_selected"] = {"BZBH": {}}
  745. if bz_selected2 != None:
  746. result3["bz_selected2"] = json.loads(bz_selected2)
  747. else:
  748. result3["bz_selected2"] = {"BZBH": {}}
  749. ####14-227+[14-228]*-2
  750. ####3-409*2
  751. ##print(r_debh)
  752. if "[" in r_debh:
  753. position3 = r_debh.find("*")
  754. coef = 1
  755. if position3 == -1:
  756. pass
  757. else:
  758. coef = r_debh[1 + position3:]
  759. ##print(coef)
  760. tail = 0
  761. for i in range(0, len(coef) + 1):
  762. if i == len(coef):
  763. tail = i
  764. break
  765. if (coef[i] > '9' or coef[i] < '0') and coef[i] != '-' and coef[i] != '.':
  766. tail = i
  767. break
  768. if tail == 0:
  769. ##print("1113111")
  770. result3["reverse"] = 'None'
  771. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  772. coef = float(coef[0:tail])
  773. position1 = r_debh.find("[")
  774. position2 = r_debh.find("]")
  775. if position2 == -1:
  776. ##print("1121111")
  777. result3["reverse"] = 'None'
  778. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  779. if r_debh[position1-1] == "+":
  780. pass
  781. elif r_debh[position1-1] == "-":
  782. coef = -coef
  783. else:
  784. ##print("111111")
  785. result3["reverse"] = 'None'
  786. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  787. debh = r_debh[position1+1: position2]
  788. if result3['GLDE']: ##csv文件里的字段,表示这个定额有没有配套的增减定额
  789. hit = False
  790. for key, value in result3['GLDE'].items():
  791. if debh in value:
  792. hit = True
  793. if not hit:
  794. result3["reverse"] = 'None'
  795. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  796. else:
  797. result3["reverse"] = 'None'
  798. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  799. result1_, result2_, rgde_, jxde_, clde_, bz_selected_, bz_selected2_, actual_zhuanye_ = await db.getSingleDeXilie(model, dingeclient, zhuanye, debh, mc)
  800. if result1_:
  801. rgde=util.mergerg(rgde, rgde_, coef)
  802. jxde=util.mergejx(jxde, jxde_, coef)
  803. clde=util.mergecl(clde, clde_, coef)
  804. result3["rgde"] = rgde
  805. result3["jxde"] = jxde
  806. result3["clde"] = clde
  807. item_ = None
  808. for item in result3['DW'].keys():
  809. item_ = item
  810. result3['DEBH'] = {item_: util.cleanBM(r_debh)}
  811. else:
  812. result3["reverse"] = 'None'
  813. elif "*" in r_debh:##1-234*1.2
  814. position3 = r_debh.find("*")
  815. coef = 1
  816. coef = r_debh[1 + position3:]
  817. ##print(coef)
  818. tail = 0
  819. for i in range(0, len(coef) + 1):
  820. if i == len(coef):
  821. tail = i
  822. break
  823. if (coef[i] > '9' or coef[i] < '0') and coef[i] != '-' and coef[i] != '.':
  824. tail = i
  825. break
  826. if tail == 0:
  827. ##print("1113111")
  828. result3["reverse"] = 'None'
  829. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  830. coef = float(coef[0:tail])
  831. util.multirg(result3["rgde"], coef)
  832. util.multijx(result3["jxde"], coef)
  833. util.multicl(result3["clde"], coef)
  834. item_ = None
  835. for item in result3['DW'].keys():
  836. item_ = item
  837. result3['DEBH'] = {item_: (r_debh)}
  838. ##print(result3)
  839. return json.dumps(service.chaifen(result3, actual_zhuanye), ensure_ascii=False)
  840. @app.post("/save/")
  841. async def save(r: Info, user=Depends(manager)):
  842. data = json.loads(r.name)
  843. ##print(data)
  844. return await db.save(client, data)
  845. @app.post("/statistics/")
  846. async def statistics(r: Info, user=Depends(manager)):
  847. ##print(data)
  848. return await db.statistics(client, r.name, user)
  849. @app.post("/zujia/")
  850. async def zujia(r: Info, user=Depends(manager)):
  851. ##print(data)
  852. return await db.zujia(client, r.name, user)
  853. @app.post("/tuijian/")
  854. async def tuijian(r: Info, user=Depends(manager)):
  855. ##print(data)
  856. return await db.tuijian(chroma_client, r.name)
  857. @app.post("/frequency/")
  858. async def frequency(r: InfoWithID, user=Depends(manager)):
  859. ##print(data)
  860. return await db.frequency(client, r.name, r.id, user)
  861. @app.post("/savedjcs/")
  862. async def savedjcs(r: Info, user=Depends(manager)):
  863. data = json.loads(r.name)
  864. ##print(data)
  865. return await db.savedjcs(client, data)
  866. @app.post("/applyFL/")
  867. async def applyFL(r: InfoWithID, user=Depends(manager)):
  868. data = json.loads(r.name)
  869. ##print(data)
  870. return await db.applyFL(client, r.id, data, user)
  871. @app.post("/xxj/")
  872. async def xxj(r: Xxj, user=Depends(manager)):
  873. return service.xxj(r.city, r.month)
  874. @app.post("/rgtz/")
  875. async def rgtz(r: Rgtz, user=Depends(manager)):
  876. glf = r.glf
  877. lr = r.lr
  878. if r.glf == '':
  879. glf = '0'
  880. if r.lr == "":
  881. lr = '0'
  882. ##return []
  883. yi = r.yi
  884. er = r.er
  885. san = r.san
  886. return await db.rgtz(client, r.biao_id, r.bh, yi, er, san, glf, lr, r.bz)
  887. @app.post("/zcfx/")
  888. async def zcfx(r: Zcfx, user=Depends(manager)):
  889. return await db.zcfx(client, r.biao_id, r.bh)
  890. @app.post("/zcfx2/")
  891. async def zcfx2(r: Zcfx2, user=Depends(manager)):
  892. return await db.zcfx2(client, r.biao_id, r.bh, r.prefix)
  893. @app.post("/jxtz/")
  894. async def jxtz(r: Jxtz, user=Depends(manager)):
  895. glf = r.glf
  896. lr = r.lr
  897. if r.glf == '':
  898. glf = '0'
  899. if r.lr == "":
  900. lr = '0'
  901. return await db.jxtz(client, r.biao_id, r.bh, r.gong, r.chaiyou, r.qiyou, r.dian, glf, lr, r.bz)
  902. @app.post("/tiaojia/")
  903. async def tiaojia(r: Tiaojia, user=Depends(manager)):
  904. ##return []
  905. glf = r.glf
  906. lr = r.lr
  907. if r.glf == '':
  908. glf = '0'
  909. if r.lr == "":
  910. lr = '0'
  911. return await db.tiaojia(client, r.biao_id, r.bh, r.bm, r.mingcheng, r.danwei, r.jiage, glf, lr, r.bz)
  912. @app.post("/searchde/")
  913. async def searchde(r: SearchDe):
  914. ##return []
  915. return await db.searchde(dingeclient, r.zhuanye, r.text)
  916. @app.post("/updatezjcs/")
  917. async def updatezjcs(r: UpdateZjcs, user=Depends(manager)):
  918. ##return []
  919. return await db.updatezjcs(client, r.biao_id, r.bh, r.mc, r.fl)
  920. @app.post("/upload/")
  921. async def upload(file: Annotated[UploadFile, File()], token: Annotated[str, Form()]):
  922. user = await manager.get_current_user(token)
  923. print(user)
  924. if file.filename.endswith('13jz') or file.filename.endswith("13jt"):
  925. content = await file.read()
  926. string = content.decode('utf-8')
  927. await resolve(string, user)
  928. return [file.filename]
  929. elif file.filename.endswith("jszf") or file.filename.endswith("JSZF"):
  930. content = await file.read()
  931. string = content.decode('utf-8')
  932. root = ET.fromstring(string)
  933. for child in root:
  934. ##print(child)
  935. if child.tag == "ZBFileContent":
  936. base64_bytes = child.text.encode("ascii")
  937. sample_string_bytes = base64.b64decode(base64_bytes)
  938. tmp = str(uuid.uuid4())
  939. os.mkdir(os.path.join("tmp", tmp))
  940. with open(tmp, "wb") as file_:
  941. file_.write(sample_string_bytes)
  942. with zipfile.ZipFile(tmp, 'r') as zip_ref:
  943. zip_ref.extractall(os.path.join("tmp", tmp))
  944. dir_list = os.listdir(os.path.join("tmp", tmp))
  945. ##print(dir_list)
  946. for entry in dir_list:
  947. if entry.endswith("13jz"):
  948. with open(os.path.join("tmp", tmp, entry), 'r') as f:
  949. await resolve(f.read(), user)
  950. return [file.filename]
  951. else:
  952. return [file.filename]
  953. @app.get("/download/{item_id}")
  954. async def download_file(item_id, user=Depends(manager)):
  955. print(user)
  956. tmp = str(uuid.uuid4())
  957. file_path = "export/contacts.xml.b"
  958. # Create the root element
  959. root = ET.Element("JingJiBiao")
  960. # Create a sub-element
  961. ##TouBiaoXx = ET.SubElement(root, "TouBiaoXx")
  962. await db.build(client, root, item_id)
  963. # Create the tree and write to a file
  964. tree = ET.ElementTree(root)
  965. tree.write("export/contacts.xml"+tmp, encoding="utf-8")
  966. dom = MD.parse("export/contacts.xml"+tmp)
  967. with open("export/contacts.xml.b" + tmp, 'w') as f:
  968. f.write("<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n")
  969. content = (dom.toprettyxml(indent=" "))
  970. content_ = content.split("\n")
  971. f.write("\n".join(content_[1:]))
  972. return FileResponse(file_path+tmp, media_type='application/octet-stream', filename="contacts.xml")
  973. async def resolve(data, user):
  974. await db.resolve(data, user, client)##manager.send_personal_message(f"You wrote: {data}", websocket)
  975. ##@app.websocket("/ws")
  976. ##async def websocket_endpoint(websocket: WebSocket):
  977. ## await manager.connect(websocket)
  978. ## try:
  979. ## while True:
  980. ## data = await websocket.receive_text()
  981. ## await resolve(websocket, data)
  982. ## ##await manager.broadcast(f"Client #{client_id} says: {data}")
  983. ## except WebSocketDisconnect:
  984. ## manager.disconnect(websocket)
  985. ## ##await manager.broadcast(f"Client left the chat")
  986. ## {'access_token': '96__yNpsN6UIOtAgfNOmu34wdt4BBnN9vZLbzCq94NCQnKoDNu7H217eM7ZMS-KZDcV9CyfpLmY80829lbJ20EFasEtBbqetdazuTYHn_8IZ34', 'expires_in': 7200, 'refresh_token': '96_JMFvhYr0scOw9pWs_ygdwYZbku9FwSbO-hcI0OVchVHoqUsXeZtZpQKCJOiq4y-LwIacvlC9huClMLTqE0CUcwugvyOV_pnr2rBYw3aTRWg', 'openid': 'oEcfS62dGXuzzAADYPzjr6OXYdJk', 'scope': 'snsapi_login', 'unionid': 'o1X7S67iVGRVbqvrjr1_UzBE4xdg'}
  987. @app.post("/token/")
  988. async def token(r : Info):
  989. response = await httpClient.get("https://api.weixin.qq.com/sns/oauth2/access_token?appid=wx74b45ac9983e4b3e&secret=bf6741ce4209a0af45f267be2abf560b&code="+ r.name + "&grant_type=authorization_code")
  990. info = (response.json())
  991. response = await httpClient.get("https://api.weixin.qq.com/sns/userinfo?access_token=" + info['access_token'] + "&openid="+ info['openid'])
  992. info = (response.json())
  993. token = manager.create_access_token(data=dict(sub=info['openid']), expires=timedelta(hours=12))
  994. return {'token' : token, 'token_type' : 'bearer', "nickname": info['nickname'], "img" : info['headimgurl'], "openid" : info["openid"]}