redis_set.py 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886
  1. import opengraph
  2. import redis
  3. from jinja2 import Environment, BaseLoader
  4. data="""
  5. {
  6. "type": "bubble",
  7. "header": {
  8. "type": "box",
  9. "layout": "vertical",
  10. "contents": [
  11. {
  12. "type": "text",
  13. "text": "集仕多 ChoozMo",
  14. "weight": "bold",
  15. "size": "xl",
  16. "color": "#ffffff"
  17. },
  18. {
  19. "type": "text",
  20. "text": "新聞 AI 主播媒體聯播網最佳方案",
  21. "size": "md",
  22. "color": "#ffffff"
  23. },
  24. {
  25. "type": "box",
  26. "layout": "baseline",
  27. "margin": "md",
  28. "contents": [
  29. {
  30. "type": "icon",
  31. "size": "xxl",
  32. "url": "https://ppt.cc/fLP10x@.png",
  33. "offsetTop": "xs"
  34. }
  35. ],
  36. "justifyContent": "flex-end",
  37. "offsetStart": "255px",
  38. "position": "absolute",
  39. "offsetBottom": "20px"
  40. }
  41. ],
  42. "backgroundColor": "#e1642b"
  43. },
  44. "hero": {
  45. "type": "image",
  46. "url": "https://ppt.cc/fDmzAx@.png",
  47. "size": "full",
  48. "aspectRatio": "20:13",
  49. "action": {
  50. "type": "uri",
  51. "uri": "http://linecorp.com/"
  52. },
  53. "offsetTop": "lg"
  54. },
  55. "body": {
  56. "type": "box",
  57. "layout": "vertical",
  58. "contents": [
  59. {
  60. "type": "text",
  61. "text": "圖文+影音+聯播",
  62. "color": "#aaaaaa",
  63. "size": "sm"
  64. },
  65. {
  66. "type": "text",
  67. "text": "全方位媒體曝光,一次到位!",
  68. "color": "#aaaaaa",
  69. "size": "sm"
  70. },
  71. {
  72. "type": "box",
  73. "layout": "baseline",
  74. "margin": "md",
  75. "contents": [
  76. {
  77. "type": "icon",
  78. "size": "md",
  79. "url": "https://ppt.cc/feXZPx@.png",
  80. "offsetTop": "xs"
  81. },
  82. {
  83. "type": "text",
  84. "text": "網路新聞圖文報導",
  85. "offsetStart": "md",
  86. "color": "#e47e4d",
  87. "weight": "bold"
  88. }
  89. ]
  90. },
  91. {
  92. "type": "box",
  93. "layout": "baseline",
  94. "margin": "md",
  95. "contents": [
  96. {
  97. "type": "icon",
  98. "size": "md",
  99. "url": "https://ppt.cc/feXZPx@.png",
  100. "offsetTop": "xs"
  101. },
  102. {
  103. "type": "text",
  104. "text": "十二家網路媒體聯播",
  105. "offsetStart": "md",
  106. "color": "#e47e4d",
  107. "weight": "bold"
  108. }
  109. ]
  110. },
  111. {
  112. "type": "box",
  113. "layout": "baseline",
  114. "margin": "md",
  115. "contents": [
  116. {
  117. "type": "icon",
  118. "size": "md",
  119. "url": "https://ppt.cc/feXZPx@.png",
  120. "offsetTop": "xs"
  121. },
  122. {
  123. "type": "text",
  124. "text": "AI 主播影音播報影片",
  125. "offsetStart": "md",
  126. "color": "#e47e4d",
  127. "weight": "bold"
  128. }
  129. ]
  130. },
  131. {
  132. "type": "box",
  133. "layout": "horizontal",
  134. "margin": "lg",
  135. "spacing": "sm",
  136. "contents": [
  137. {
  138. "type": "text",
  139. "text": "一次到位擁有,只要",
  140. "margin": "none",
  141. "size": "sm",
  142. "gravity": "center",
  143. "color": "#2384e3",
  144. "weight": "bold"
  145. },
  146. {
  147. "type": "text",
  148. "text": "$36,000",
  149. "size": "xxl",
  150. "offsetStart": "5px",
  151. "weight": "bold",
  152. "color": "#2384e3"
  153. }
  154. ],
  155. "backgroundColor": "#fff3ed",
  156. "background": {
  157. "type": "linearGradient",
  158. "angle": "0deg",
  159. "startColor": "#fff3ed",
  160. "endColor": "#ffffff"
  161. }
  162. },
  163. {
  164. "type": "text",
  165. "text": "不論是公司宣傳/產品發表/品牌經營,都能透過新聞稿發布,提升曝光及知名度!",
  166. "wrap": true,
  167. "size": "13px",
  168. "align": "start",
  169. "offsetTop": "10px"
  170. }
  171. ]
  172. },
  173. "footer": {
  174. "type": "box",
  175. "layout": "vertical",
  176. "spacing": "sm",
  177. "contents": [
  178. {
  179. "type": "box",
  180. "layout": "vertical",
  181. "contents": [
  182. {
  183. "type": "button",
  184. "style": "link",
  185. "height": "sm",
  186. "action": {
  187. "type": "uri",
  188. "label": "請來採訪我",
  189. "uri": "https://page.line.me/choozmo"
  190. },
  191. "color": "#FFFFFF"
  192. }
  193. ],
  194. "backgroundColor": "#e47e4d",
  195. "offsetTop": "-3px"
  196. },
  197. {
  198. "type": "box",
  199. "layout": "vertical",
  200. "contents": [
  201. {
  202. "type": "button",
  203. "style": "link",
  204. "height": "sm",
  205. "action": {
  206. "type": "uri",
  207. "label": "了解更多",
  208. "uri": "https://page.line.me/choozmo"
  209. },
  210. "color": "#FFFFFF"
  211. }
  212. ],
  213. "backgroundColor": "#06C152"
  214. }
  215. ],
  216. "flex": 0
  217. }
  218. }
  219. """
  220. data2="""
  221. {
  222. "type": "bubble",
  223. "header": {
  224. "type": "box",
  225. "layout": "vertical",
  226. "contents": [
  227. {
  228. "type": "text",
  229. "text": "集仕多 ChoozMo",
  230. "weight": "bold",
  231. "size": "xl",
  232. "color": "#ffffff"
  233. },
  234. {
  235. "type": "text",
  236. "text": "新聞 AI 主播媒體聯播網最佳方案",
  237. "size": "md",
  238. "color": "#ffffff"
  239. },
  240. {
  241. "type": "box",
  242. "layout": "baseline",
  243. "margin": "md",
  244. "contents": [
  245. {
  246. "type": "icon",
  247. "size": "xxl",
  248. "url": "https://ppt.cc/fLP10x@.png",
  249. "offsetTop": "xs"
  250. }
  251. ],
  252. "justifyContent": "flex-end",
  253. "offsetStart": "255px",
  254. "position": "absolute",
  255. "offsetBottom": "20px"
  256. }
  257. ],
  258. "backgroundColor": "#e1642b"
  259. },
  260. "hero": {
  261. "type": "image",
  262. "url": "https://ppt.cc/fDmzAx@.png",
  263. "size": "full",
  264. "aspectRatio": "20:13",
  265. "offsetTop": "lg"
  266. },
  267. "body": {
  268. "type": "box",
  269. "layout": "vertical",
  270. "contents": [
  271. {
  272. "type": "text",
  273. "text": "圖文+影音+聯播",
  274. "color": "#aaaaaa",
  275. "size": "sm"
  276. },
  277. {
  278. "type": "text",
  279. "text": "全方位媒體曝光,一次到位!",
  280. "color": "#aaaaaa",
  281. "size": "sm"
  282. },
  283. {
  284. "type": "box",
  285. "layout": "baseline",
  286. "margin": "md",
  287. "contents": [
  288. {
  289. "type": "icon",
  290. "size": "md",
  291. "url": "https://ppt.cc/feXZPx@.png",
  292. "offsetTop": "xs"
  293. },
  294. {
  295. "type": "text",
  296. "text": "網路新聞圖文報導",
  297. "offsetStart": "md",
  298. "color": "#e47e4d",
  299. "weight": "bold"
  300. }
  301. ]
  302. },
  303. {
  304. "type": "box",
  305. "layout": "baseline",
  306. "margin": "md",
  307. "contents": [
  308. {
  309. "type": "icon",
  310. "size": "md",
  311. "url": "https://ppt.cc/feXZPx@.png",
  312. "offsetTop": "xs"
  313. },
  314. {
  315. "type": "text",
  316. "text": "十二家網路媒體聯播",
  317. "offsetStart": "md",
  318. "color": "#e47e4d",
  319. "weight": "bold"
  320. }
  321. ]
  322. },
  323. {
  324. "type": "box",
  325. "layout": "baseline",
  326. "margin": "md",
  327. "contents": [
  328. {
  329. "type": "icon",
  330. "size": "md",
  331. "url": "https://ppt.cc/feXZPx@.png",
  332. "offsetTop": "xs"
  333. },
  334. {
  335. "type": "text",
  336. "text": "AI 主播影音播報影片",
  337. "offsetStart": "md",
  338. "color": "#e47e4d",
  339. "weight": "bold"
  340. }
  341. ]
  342. },
  343. {
  344. "type": "box",
  345. "layout": "horizontal",
  346. "margin": "lg",
  347. "spacing": "sm",
  348. "contents": [
  349. {
  350. "type": "text",
  351. "text": "一次到位擁有,只要",
  352. "margin": "none",
  353. "size": "sm",
  354. "gravity": "center",
  355. "color": "#2384e3",
  356. "weight": "bold"
  357. },
  358. {
  359. "type": "text",
  360. "text": "$36,000",
  361. "size": "xxl",
  362. "offsetStart": "5px",
  363. "weight": "bold",
  364. "color": "#2384e3"
  365. }
  366. ],
  367. "backgroundColor": "#fff3ed",
  368. "background": {
  369. "type": "linearGradient",
  370. "angle": "0deg",
  371. "startColor": "#fff3ed",
  372. "endColor": "#ffffff"
  373. }
  374. },
  375. {
  376. "type": "text",
  377. "text": "不論是公司宣傳/產品發表/品牌經營,都能透過新聞稿發布,提升曝光及知名度!",
  378. "wrap": true,
  379. "size": "13px",
  380. "align": "start",
  381. "offsetTop": "10px"
  382. }
  383. ]
  384. },
  385. "footer": {
  386. "type": "box",
  387. "layout": "vertical",
  388. "spacing": "sm",
  389. "contents": [
  390. {
  391. "type": "box",
  392. "layout": "vertical",
  393. "contents": [
  394. {
  395. "type": "button",
  396. "style": "link",
  397. "height": "sm",
  398. "action": {
  399. "type": "uri",
  400. "label": "請來採訪我",
  401. "uri": "https://page.line.me/choozmo"
  402. },
  403. "color": "#FFFFFF"
  404. }
  405. ],
  406. "backgroundColor": "#e47e4d",
  407. "offsetTop": "-3px"
  408. },
  409. {
  410. "type": "box",
  411. "layout": "vertical",
  412. "contents": [
  413. {
  414. "type": "button",
  415. "style": "link",
  416. "height": "sm",
  417. "action": {
  418. "type": "uri",
  419. "label": "了解更多",
  420. "uri": "https://ai.choozmo.com/"
  421. },
  422. "color": "#FFFFFF"
  423. }
  424. ],
  425. "backgroundColor": "#06C152"
  426. },
  427. {
  428. "type": "box",
  429. "layout": "horizontal",
  430. "contents": [
  431. {
  432. "type": "image",
  433. "url": "https://ppt.cc/fHYTTx@.png",
  434. "offsetStart": "35px",
  435. "size": "xl",
  436. "position": "absolute"
  437. },
  438. {
  439. "type": "text",
  440. "text": "技術提供",
  441. "offsetBottom": "15px",
  442. "color": "#8B8B8B",
  443. "size": "sm",
  444. "weight": "bold",
  445. "offsetEnd": "40px",
  446. "position": "absolute"
  447. }
  448. ],
  449. "action": {
  450. "type": "uri",
  451. "label": "action",
  452. "uri": "https://page.line.me/choozmo"
  453. },
  454. "width": "100%",
  455. "height": "50px",
  456. "alignItems": "center",
  457. "offsetTop": "5px"
  458. }
  459. ],
  460. "flex": 0,
  461. "height": "160px"
  462. }
  463. }
  464. """
  465. bubble="""
  466. {
  467. "type": "bubble",
  468. "size": "micro",
  469. "hero": {
  470. "type": "image",
  471. "url": "https://scdn.line-apps.com/n/channel_devcenter/img/flexsnapshot/clip/clip10.jpg",
  472. "size": "full",
  473. "aspectMode": "cover",
  474. "aspectRatio": "320:213"
  475. },
  476. "body": {
  477. "type": "box",
  478. "layout": "vertical",
  479. "contents": [
  480. {
  481. "type": "text",
  482. "text": "{{title }}",
  483. "weight": "bold",
  484. "size": "sm",
  485. "wrap": true
  486. },
  487. {
  488. "type": "box",
  489. "layout": "vertical",
  490. "contents": [
  491. {
  492. "type": "box",
  493. "layout": "baseline",
  494. "spacing": "sm",
  495. "contents": [
  496. {
  497. "type": "text",
  498. "text": "ChoozMo商情AI",
  499. "wrap": true,
  500. "color": "#8c8c8c",
  501. "size": "xs",
  502. "flex": 5
  503. }
  504. ]
  505. }
  506. ]
  507. }]
  508. }
  509. }
  510. """
  511. bubble2="""
  512. {
  513. "type": "bubble",
  514. "header": {
  515. "type": "box",
  516. "layout": "horizontal",
  517. "position": "relative",
  518. "backgroundColor": "#FFFFFFFF",
  519. "contents": [
  520. {
  521. "type": "box",
  522. "layout": "vertical",
  523. "contents": [
  524. {
  525. "type": "image",
  526. "url": "https://i.imgur.com/wQbJeGc.png",
  527. "margin": "none",
  528. "align": "end",
  529. "gravity": "top",
  530. "size": "md",
  531. "aspectRatio": "16:5",
  532. "action": {
  533. "type": "uri",
  534. "label": "ChoozMo",
  535. "uri": "https://cmm.ai/line"
  536. }
  537. },
  538. {
  539. "type": "text",
  540. "text": "今日熱搜",
  541. "weight": "bold",
  542. "color": "#BEB7B7FF",
  543. "position": "absolute",
  544. "offsetTop": "5px",
  545. "contents": []
  546. }
  547. ]
  548. }
  549. ]
  550. },
  551. "hero": {
  552. "type": "image",
  553. "url": "https://scdn.line-apps.com/n/channel_devcenter/img/fx/01_4_news.png",
  554. "size": "full",
  555. "aspectRatio": "20:13",
  556. "aspectMode": "cover",
  557. "action": {
  558. "type": "uri",
  559. "label": "Action",
  560. "uri": "https://linecorp.com/"
  561. }
  562. },
  563. "body": {
  564. "type": "box",
  565. "layout": "horizontal",
  566. "spacing": "md",
  567. "contents": [
  568. {
  569. "type": "spacer"
  570. },
  571. {
  572. "type": "box",
  573. "layout": "vertical",
  574. "contents": [
  575. {
  576. "type": "text",
  577. "text": "A1",
  578. "size": "xs",
  579. "flex": 1,
  580. "gravity": "top",
  581. "contents": []
  582. },
  583. {
  584. "type": "text",
  585. "text": "A2",
  586. "size": "xs",
  587. "flex": 2,
  588. "gravity": "center",
  589. "contents": []
  590. },
  591. {
  592. "type": "text",
  593. "text": "A3",
  594. "size": "xs",
  595. "flex": 2,
  596. "gravity": "center",
  597. "contents": []
  598. },
  599. {
  600. "type": "text",
  601. "text": "A4",
  602. "size": "xs",
  603. "flex": 1,
  604. "gravity": "bottom",
  605. "contents": []
  606. },
  607. {
  608. "type": "spacer"
  609. }
  610. ]
  611. }
  612. ]
  613. },
  614. "footer": {
  615. "type": "box",
  616. "layout": "horizontal",
  617. "contents": [
  618. {
  619. "type": "button",
  620. "action": {
  621. "type": "uri",
  622. "label": "More",
  623. "uri": "https://cmm.ai/line"
  624. }
  625. }
  626. ]
  627. }
  628. }
  629. """
  630. bubble3="""
  631. {
  632. "type": "bubble",
  633. "direction": "ltr",
  634. "header": {
  635. "type": "box",
  636. "layout": "vertical",
  637. "contents": [
  638. {
  639. "type": "box",
  640. "layout": "horizontal",
  641. "action": {
  642. "type": "uri",
  643. "uri": "https://page.line.me/choozmo"
  644. },
  645. "width": "100%",
  646. "contents": [
  647. {
  648. "type": "text",
  649. "text": "今日熱搜",
  650. "align": "start",
  651. "contents": []
  652. },
  653. {
  654. "type": "image",
  655. "url": "https://i.imgur.com/wQbJeGc.png",
  656. "align": "end",
  657. "aspectRatio": "4:1",
  658. "aspectMode": "cover"
  659. }
  660. ]
  661. }
  662. ]
  663. },
  664. "body": {
  665. "type": "box",
  666. "layout": "vertical",
  667. "paddingAll": "0px",
  668. "width": "100%",
  669. "backgroundColor": "#000000FF",
  670. "action": {
  671. "type": "uri",
  672. "uri": "{{ qlink }}"
  673. },
  674. "contents": [
  675. {
  676. "type": "box",
  677. "layout": "vertical",
  678. "contents": [
  679. {
  680. "type": "image",
  681. "url": "{{ imgurl }}",
  682. "size": "full",
  683. "aspectMode": "cover"
  684. },
  685. {
  686. "type": "box",
  687. "layout": "vertical",
  688. "position": "absolute",
  689. "offsetBottom": "0px",
  690. "width": "100%",
  691. "height": "90px",
  692. "backgroundColor": "#9C8E7ECC",
  693. "contents": [
  694. {
  695. "type": "text",
  696. "text": "{{ imgtitle }}",
  697. "color": "#FFFFFFFF",
  698. "align": "start",
  699. "wrap": true,
  700. "contents": []
  701. }
  702. ]
  703. }
  704. ]
  705. },
  706. {
  707. "type": "box",
  708. "layout": "horizontal",
  709. "position": "absolute",
  710. "offsetTop": "10px",
  711. "offsetStart": "5px",
  712. "width": "100px",
  713. "borderWidth": "1px",
  714. "backgroundColor": "#898CDFFF",
  715. "cornerRadius": "5px",
  716. "contents": [
  717. {
  718. "type": "text",
  719. "text": "{{title}}",
  720. "color": "#FFFFFFFF",
  721. "align": "center",
  722. "contents": []
  723. }
  724. ]
  725. }
  726. ]
  727. },
  728. "footer": {
  729. "type": "box",
  730. "layout": "vertical",
  731. "contents": [
  732. {
  733. "type": "text",
  734. "text": "相關關鍵字",
  735. "contents": []
  736. },
  737. {
  738. "type": "separator"
  739. },
  740. {
  741. "type": "box",
  742. "layout": "horizontal",
  743. "contents": [
  744. {
  745. "type": "text",
  746. "text": "{{K1}}",
  747. "contents": []
  748. },
  749. {
  750. "type": "text",
  751. "text": "{{K2}}",
  752. "contents": []
  753. }
  754. ]
  755. },
  756. {
  757. "type": "box",
  758. "layout": "horizontal",
  759. "contents": [
  760. {
  761. "type": "text",
  762. "text": "{{K3}}",
  763. "contents": []
  764. },
  765. {
  766. "type": "text",
  767. "text": "{{K4}}",
  768. "contents": []
  769. }
  770. ]
  771. }
  772. ]
  773. }
  774. }
  775. """
  776. data3_begin="""
  777. {
  778. "type": "carousel",
  779. "contents": [
  780. """
  781. data3_end="""
  782. ]
  783. }
  784. """
  785. import dataset
  786. import json
  787. import sys
  788. #from opengraph import OpenGraph
  789. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/gtrends?charset=utf8mb4')
  790. cursor=db.query('SELECT distinct qtitle FROM gtrends.trending_search_flat order by dt desc limit 5')
  791. qtitles=[]
  792. for c in cursor:
  793. qtitles.append(c['qtitle'])
  794. result=[]
  795. for qt in qtitles:
  796. cursor=db.query('SELECT distinct trending_search_flat.qtitle,trending_search_flat.atitle,trending_search_flat.aimg,trending_search_flat.aurl,kw_related.original,kw_related.kw FROM gtrends.trending_search_flat,kw_related where trending_search_flat.qtitle=kw_related.original and trending_search_flat.qtitle="'+qt+'" order by trending_search_flat.dt desc')
  797. title=None
  798. imgurl=None
  799. imgtitle=qlink=None
  800. k1=k2=k3=k4=None
  801. lst_dict={}
  802. for c in cursor:
  803. title=c['qtitle']
  804. qlink=c['aurl']
  805. imgtitle=c['atitle']
  806. # imgurl=c['aimg']
  807. print(qlink)
  808. if imgurl is None:
  809. try:
  810. video = opengraph.OpenGraph(url=qlink)
  811. if video.is_valid():
  812. if video['image'] is not None:
  813. imgurl=video['image']
  814. print(imgurl)
  815. except:
  816. imgurl=None
  817. lst_dict[c['kw']]=1
  818. if len(lst_dict)>=4:
  819. break
  820. if imgurl is None:
  821. print('none')
  822. imgurl=c['aimg']
  823. print(lst_dict)
  824. lst=list(lst_dict.keys())
  825. k1=lst[0]
  826. k2=lst[1]
  827. if len(lst)>=3:
  828. k3=lst[2]
  829. else:
  830. k3=' '
  831. if len(lst)>=4:
  832. k4=lst[3]
  833. else:
  834. k4=' '
  835. result.append({'title':title,'imgurl':imgurl,'qlink':qlink,'imgtitle':imgtitle,'K1':k1,'K2':k2,'K3':k3,'K4':k4})
  836. result_lst=result
  837. print(result)
  838. r = redis.Redis(host='db.ptt.cx', port=6379, db=2,password='choozmo9')
  839. rtemplate = Environment(loader=BaseLoader).from_string(bubble3)
  840. result=""
  841. for r2 in result_lst:
  842. # r3 = rtemplate.render({'title':title,'imgurl':imgurl,'qlink':qlink,'imgtitle':imgtitle,'K1':k1,'K2':k2,'K3':k3,'K4':k4})
  843. r3 = rtemplate.render(r2)
  844. result+=r3
  845. result+=','
  846. result=result[:-1]
  847. final_result=data3_begin+result+data3_end
  848. full_result='{"title":"今日熱搜關鍵字","data":'+final_result+'}'
  849. #final_result=data3_begin+result+data3_end
  850. print(final_result)
  851. #r.set('btn_data',final_result)
  852. r.set('btn_data',full_result)
  853. #r.set('btn_data',data2)
  854. sys.exit()