####### import os from typing import Optional from dataset.util import ResultIter from fastapi import FastAPI from fastapi.middleware.cors import CORSMiddleware from pytrends.request import TrendReq from datetime import tzinfo import datetime import mysql.connector from mysql.connector import Error from io import BytesIO from fastapi.responses import StreamingResponse import xlsxwriter import pandas as pd import dataset import json from pytube import extract app = FastAPI() origins = [ "*" ] app.add_middleware( CORSMiddleware, allow_origins=origins, allow_credentials=True, allow_methods=["*"], allow_headers=["*"], ) #https://m3.hhh.com.tw:18687/docs hhhMBPath = '../hhh-home-mb' hhhPCPath = '../hhh-home-pc' # db = dataset.connect( # 'mysql://hhh7796hhh:lYmWsu^ujcA1@hhh-v57.cmab1ctkglka.ap-northeast-2.rds.amazonaws.com:3306/xoops?charset=utf8mb4') #2022/12/13 change db = dataset.connect('mysql://hhh7796hhh:lYmWsu^ujcA1@ec2-3-35-26-49.ap-northeast-2.compute.amazonaws.com:3306/xoops?charset=utf8mb4') def ExecuteQuery(isql): #2022/12/13 change #host='hhh-v57.cmab1ctkglka.ap-northeast-2.rds.amazonaws.com', connection = mysql.connector.connect( host='ec2-3-35-26-49.ap-northeast-2.compute.amazonaws.com', database='xoops', user='hhh7796hhh', password='lYmWsu^ujcA1', use_unicode=True, charset='utf8', collation='utf8_unicode_ci' ) # connection.set_charset_collation('utf8','utf8_general_ci') cursor = connection.cursor(dictionary=True) cursor.execute(isql) if cursor.rowcount == -1: return cursor.fetchall() else: connection.commit() return cursor.rowcount def ExecuteCmd(isql): #2022/12/13 change #host='hhh-v57.cmab1ctkglka.ap-northeast-2.rds.amazonaws.com', connection = mysql.connector.connect( host='ec2-3-35-26-49.ap-northeast-2.compute.amazonaws.com', database='xoops', user='hhh7796hhh', password='lYmWsu^ujcA1' ) cursor = connection.cursor(dictionary=True) cursor.execute(isql) print(cursor.rowcount) connection.commit() return None @app.get("/ExportExecuteDetail") async def ExportExecuteDetail(): output = BytesIO() records = ExecuteQuery(""" select f.exf_id, num 合約, company 合約公司,lv1 大項目,lv2 執行項, contract_time 合約到期日,price 金額,sales_man 業務,quota 額度,creator 建立者,is_close 狀態,sdate 上架日期,edate 下架日期,f.note 備註,designer 設計師,mobile 手機,telete 電話,contract_person 聯絡人,detail_status 合約名稱,d.create_time 建立時間,d.update_time 更新時間,last_update 最後更新 from execute_form f left join execute_detail d on f.exf_id=d.exf_id where f.is_delete='N' order BY f.exf_id DESC, exd_id """) df = pd.DataFrame(list(records)) writer = pd.ExcelWriter(output) df.to_excel(writer, sheet_name='bar') writer.save() """ workbook = xlsxwriter.Workbook(output) worksheet = workbook.add_worksheet() for cols in records: worksheet.write(0, 0, 'ISBN') worksheet.write(0, 1, 'Name') worksheet.write(0, 2, 'Takedown date') worksheet.write(0, 3, 'Last updated') workbook.close() """ output.seek(0) headers = { 'Content-Disposition': 'attachment; filename="execute_detail_all.xlsx"' } return StreamingResponse(output, headers=headers, media_type='application/octet-stream') @app.get("/") def read_root(): return {"Hello": "World"} @app.get("/movexoopstostage") def movexoopstostage(designerid: str = "0", caseid: str = "0"): ExecuteQuery( "replace INTO stage._hdesigner SELECT * FROM xoops._hdesigner WHERE hdesigner_id IN ('" + designerid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hcase SELECT * FROM xoops._hcase WHERE hcase_id IN ('"+caseid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hcase_img SELECT * FROM xoops._hcase_img WHERE hcase_id IN ('"+caseid.replace(',', "','")+"');") return {"success"} @app.get("/movepxoopstostage") def movepxoopstostage(brandid: str = "0", productid: str = "0"): ExecuteQuery( "replace INTO stage._hbrand SELECT * FROM xoops._hbrand WHERE hbrand_id IN ('" + brandid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hbrand_page SELECT * FROM xoops._hbrand_page WHERE hbrand_id IN ('" + brandid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hproduct SELECT * FROM xoops._hproduct WHERE id IN ('"+productid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hproduct_img SELECT * FROM xoops._hproduct_img WHERE hproduct_id IN ('"+productid.replace(',', "','")+"');") return {"success"} @app.get("/movecxoopstostage") def movecxoopstostage(columnid: str = "0"): ExecuteQuery( "replace INTO stage._hcolumn SELECT * FROM xoops._hcolumn WHERE hcolumn_id IN ('" + columnid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hcolumn_img SELECT * FROM xoops._hcolumn_img WHERE hcolumn_id IN ('" + columnid.replace(',', "','")+"');") ExecuteQuery( "replace INTO stage._hcolumn_page SELECT * FROM xoops._hcolumn_page WHERE hcolumn_id IN ('" + columnid.replace(',', "','")+"');") return {"success"} @app.get("/genjson") def genjson(filename: str = "realtime.json"): jData = json.load(open(hhhMBPath+'/json/data.json', encoding='utf8')) records = ExecuteQuery("SELECT * FROM _had where (now() between start_time and end_time or ( start_time is null and end_time is null) or ( start_time = '0000-00-00 00:00:00' and end_time = '0000-00-00 00:00:00')) and onoff='1' and adtype like '首八大%' ") for x in jData: # 頂部輪播區-新刊頭 if x['id'] == 0: records = ExecuteQuery("""SELECT adlogo lo,adlogo_mobile mlo, adhref lk, adlogo_mobile_webp lomwebp, adlogo_webp dwebp FROM _had WHERE adtype LIKE '新刊頭%' AND onoff='1' AND(NOW() BETWEEN start_time AND end_time OR(start_time='0000-00-00 00:00:00' and end_time='0000-00-00 00:00:00') or (start_time is null and end_time is NULL)) ORDER BY cast(SUBSTR(adtype,4) AS DECIMAL)""") x["data"] = [] for c in records: a = {'imgUrl': c['mlo'], 'link': str( c['lk']), 'DimgUrl': c['lo'], 'webp': str(c['lomwebp']), 'Dwebp': str(c['dwebp'])} x["data"].append(a) # print(x["data"]) # 主要輪播區-首八大 if x['id'] == 1: records = ExecuteQuery("""SELECT adlogo lo,adlogo_mobile mlo, adhref lk, adlogo_mobile_webp lomwebp, adlogo_webp dwebp FROM _had WHERE adtype LIKE '首八大%' AND onoff='1' AND(NOW() BETWEEN start_time AND end_time OR(start_time='0000-00-00 00:00:00' and end_time='0000-00-00 00:00:00') or (start_time is null and end_time is NULL)) ORDER BY cast(SUBSTR(adtype,4) AS DECIMAL)""") x["data"] = [] for c in records: a = {'imgUrl': c['mlo'], 'link': str( c['lk']), 'DimgUrl': c['lo'], 'webp': str(c['lomwebp']), 'Dwebp': str(c['dwebp'])} x["data"].append(a) # print(x["data"]) #tab區塊-最夯設計, 影音實錄, 專欄文章 if x['id'] == 2: x["data"] = [] records = ExecuteQuery("""SELECT caption TT ,cover IMG, CONCAT('https://hhh.com.tw/cases/detail/',hcase_id,'/') LK, short_desc txt from _hcase left join _hdesigner ON _hcase.hdesigner_id=_hdesigner.hdesigner_id WHERE _hcase.onoff='1' AND _hdesigner.onoff='1' AND(NOW() > sdate) ORDER BY hcase_id DESC LIMIT 3""") a = {'tab': '最夯設計', 'data': []} for c in records: ad = {'imgUrl': c['IMG'], 'link': c['LK'], 'title': c['TT'], 'description': c['txt']} a['data'].append(ad) x["data"].append(a) records = ExecuteQuery("""SELECT title TT,iframe IMG , CONCAT('https://hhh.com.tw/video-post.php?id=',hvideo_id) LK , name from _hvideo ORDER BY hvideo_id DESC LIMIT 4""") a = {'tab': '影音實錄', 'data': []} cnt = 0 for c in records: if cnt == 0: cnt += 1 continue tid = extract.video_id(c['IMG']) timg = "https://img.youtube.com/vi/" + tid+"/hqdefault.jpg" ad = {'imgUrl': timg, 'link': c['LK'], 'title': c['name'], 'description': c['TT']} a['data'].append(ad) x["data"].append(a) records = ExecuteQuery("""SELECT ctitle TT,clogo IMG, CONCAT('https://hhh.com.tw/columns/detail/',hcolumn_id,'/') LK, cdesc from _hcolumn WHERE onoff='1' AND NOW() > sdate ORDER BY hcolumn_id DESC LIMIT 3""") a = {'tab': '專欄文章', 'data': []} for c in records: ad = {'imgUrl': c['IMG'], 'link': c['LK'], 'title': c['TT'], 'description': c['cdesc']} a['data'].append(ad) x["data"].append(a) # print(x["data"]) # 主題企劃區 if x['id'] == 3: records = ExecuteQuery("""SELECT logo lo, CONCAT('https://hhh.com.tw/topic/detail/',htopic_id,'/') lk, `desc`, title FROM _htopic WHERE onoff = '1' ORDER BY htopic_id DESC limit 3""") x["data"] = [] for c in records: a = {'imgUrl': c['lo'], 'link': str( c['lk']), 'video': 'false', 'description': c['desc'], 'title': c['title']} x["data"].append(a) # print(x["data"]) # 編輯精選 if x['id'] == 4: records = ExecuteQuery("""SELECT hcolumn_id, ctitle, clogo,cdesc FROM homepage_set LEFT JOIN _hcolumn ON mapping_id = hcolumn_id WHERE outer_set=8 AND homepage_set.onoff='Y' AND(NOW() BETWEEN homepage_set.start_time AND homepage_set.end_time OR(homepage_set.start_time='0000-00-00 00:00:00' and homepage_set.end_time='0000-00-00 00:00:00') or (homepage_set.start_time is null and homepage_set.end_time is NULL)) ORDER BY inner_sort""") x["data"] = [] for c in records: a = {'imgUrl': c['clogo'], 'link': "https://hhh.com.tw/columns/detail/" + str( c['hcolumn_id']) + "/", 'title': c['ctitle'], 'video': 'false', 'description': c['cdesc']} x["data"].append(a) # print(x["data"]) # 首列表廣告 if x['id'] == 5: records = ExecuteQuery("""SELECT adlogo lo,adlogo_mobile mlo, adhref lk, adlogo_mobile_webp lomwebp, adlogo_webp dwebp FROM _had WHERE adtype LIKE '首列表廣告%' AND onoff='1' AND(NOW() BETWEEN start_time AND end_time OR(start_time='0000-00-00 00:00:00' and end_time='0000-00-00 00:00:00') or (start_time is null and end_time is NULL)) ORDER BY adtype""") x["data"] = [] for c in records: a = {'imgUrl': c['mlo'], 'link': str( c['lk']), 'DimgUrl': c['lo'], 'webp': str(c['lomwebp']), 'Dwebp': str(c['dwebp'])} x["data"].append(a) # print(x["data"]) # 來選好物區 if x['id'] == 6: records = ExecuteQuery( "SELECT max_row from outer_site_set WHERE title='來選好貨'") maxrow = 1 for c in records: maxrow = c['max_row'] records = ExecuteQuery("""(SELECT theme_type, mapping_id, IFNULL(ifnull(ifnull(_hcase.caption,_hcolumn.ctitle),_hproduct.name),_hvideo.title) COLLATE utf8_general_ci caption , IFNULL(ifnull(_hcase.cover,_hcolumn.clogo),_hproduct.cover) COLLATE utf8_general_ci J, iframe , IFNULL(ifnull(ifnull(_hcase.short_desc,_hcolumn.cdesc),_hproduct.descr),_hvideo.`desc`) COLLATE utf8_general_ci short_desc , (case when theme_type='case' then CONCAT('https://hhh.com.tw/cases/detail/d/',mapping_id) when theme_type='column' then CONCAT('https://hhh.com.tw/columns/detail/',mapping_id) when theme_type='product' then CONCAT('https://hhh.com.tw/product-post.php?id=',mapping_id) when theme_type='video' then CONCAT('https://hhh.com.tw/video-post.php?id=',mapping_id) ELSE '' END) url -- SELECT * FROM homepage_set left join _hcase ON _hcase.hcase_id=homepage_set.mapping_id AND theme_type='case'-- AND _hcase.onoff = '1' LEFT JOIN _hproduct ON mapping_id = _hproduct.id AND theme_type='product'-- AND _hproduct.onoff = '1' LEFT JOIN _hcolumn ON mapping_id = _hcolumn.hcolumn_id AND theme_type='column'-- AND _hcolumn.onoff = '1' LEFT JOIN _hvideo ON mapping_id = _hvideo.hvideo_id AND theme_type='video' WHERE homepage_set.onoff='Y' AND outer_set = (SELECT oss_id from outer_site_set WHERE title='來選好貨') AND(NOW() BETWEEN homepage_set.start_time AND homepage_set.end_time OR(homepage_set.start_time='0000-00-00 00:00:00' and homepage_set.end_time='0000-00-00 00:00:00') or (homepage_set.start_time is null and homepage_set.end_time is NULL)) ORDER BY outer_set, inner_sort) UNION (SELECT 'product', id, `name`, cover, NULL ,descr ,CONCAT('https://hhh.com.tw/product-post.php?id=',id) FROM _hproduct WHERE onoff='1' ORDER BY id DESC LIMIT """ + str(maxrow) + """) LIMIT """ + str(maxrow)) x["data"] = [] for c in records: #print(c) if c['iframe'] is None: if isinstance(c['J'], bytearray) or isinstance(c['J'], bytes): c['J'] = c['J'].decode('utf8') if isinstance(c['caption'], bytearray) or isinstance(c['caption'], bytes): c['caption'] = c['caption'].decode('utf8') if isinstance(c['short_desc'], bytearray) or isinstance(c['short_desc'], bytes): c['short_desc'] = c['short_desc'].decode('utf8') a = {'imgUrl': c['J'], 'link': c['url'], 'title': c['caption'], 'description': c['short_desc'], 'video': 'false'} else: tid = extract.video_id(str(c['iframe'])) timg = "https://img.youtube.com/vi/" + tid+"/hqdefault.jpg" ccaption = "" cdescription = "" if isinstance(c['caption'], bytearray): ccaption = str(c['caption'].decode('utf8')) else: ccaption = str(c['caption']) if c['short_desc'] is not None: if isinstance(c['short_desc'], bytes): cdescription = str(c['short_desc'].decode('utf8')) else: cdescription = str(c['short_desc']) a = {'imgUrl': timg, 'link': c['url'], 'title': ccaption, 'description': cdescription, 'video': tid} x["data"].append(a) # print(x["data"]) # 本週推薦 if x['id'] == 7: records = ExecuteQuery( "SELECT max_row from outer_site_set WHERE title='本週推薦'") maxrow = 1 for c in records: maxrow = c['max_row'] records = ExecuteQuery("""SELECT theme_type, mapping_id, IFNULL(ifnull(ifnull(_hcase.caption,_hcolumn.ctitle),_hproduct.name),_hvideo.title) caption , IFNULL(ifnull(_hcase.cover,_hcolumn.clogo),_hproduct.cover) J, iframe , IFNULL(ifnull(ifnull(_hcase.short_desc,_hcolumn.cdesc),_hproduct.descr),_hvideo.`desc`) short_desc , (case when theme_type='case' then CONCAT('https://hhh.com.tw/cases/detail/d/',mapping_id) when theme_type='column' then CONCAT('https://hhh.com.tw/columns/detail/',mapping_id) when theme_type='product' then CONCAT('https://hhh.com.tw/product-post.php?id=',mapping_id) when theme_type='video' then CONCAT('https://hhh.com.tw/video-post.php?id=',mapping_id) ELSE '' END) url -- SELECT * FROM homepage_set left join _hcase ON _hcase.hcase_id=homepage_set.mapping_id AND theme_type='case'-- AND _hcase.onoff = '1' LEFT JOIN _hproduct ON mapping_id = _hproduct.id AND theme_type='product'-- AND _hproduct.onoff = '1' LEFT JOIN _hcolumn ON mapping_id = _hcolumn.hcolumn_id AND theme_type='column'-- AND _hcolumn.onoff = '1' LEFT JOIN _hvideo ON mapping_id = _hvideo.hvideo_id AND theme_type='video' WHERE homepage_set.onoff='Y' AND outer_set = (SELECT oss_id from outer_site_set WHERE title='本週推薦') AND(NOW() BETWEEN homepage_set.start_time AND homepage_set.end_time OR(homepage_set.start_time='0000-00-00 00:00:00' and homepage_set.end_time='0000-00-00 00:00:00') or (homepage_set.start_time is null and homepage_set.end_time is NULL)) ORDER BY outer_set, inner_sort LIMIT """ + str(maxrow)) x["data"] = [] for c in records: if c['iframe'] is None: if isinstance(c['J'], bytearray) or isinstance(c['J'], bytes): c['J'] = c['J'].decode('utf8') if isinstance(c['caption'], bytearray) or isinstance(c['caption'], bytes): c['caption'] = c['caption'].decode('utf8') if isinstance(c['short_desc'], bytearray) or isinstance(c['short_desc'], bytes): c['short_desc'] = c['short_desc'].decode('utf8') a = {'imgUrl': c['J'], 'link': c['url'], 'title': c['caption'], 'description': c['short_desc'], 'video': 'false'} else: tid = extract.video_id(str(c['iframe'])) timg = "https://img.youtube.com/vi/" + tid+"/hqdefault.jpg" ccaption = "" cdescription = "" if isinstance(c['caption'], bytearray): ccaption = str(c['caption'].decode('utf8')) else: ccaption = str(c['caption']) if c['short_desc'] is not None: if isinstance(c['short_desc'], bytes): cdescription = str(c['short_desc'].decode('utf8')) else: cdescription = str(c['short_desc']) a = {'imgUrl': timg, 'link': c['url'], 'title': ccaption, 'description': cdescription, 'video': tid} x["data"].append(a) # print(x["data"]) # 粉絲推薦 if x['id'] == 8: records = ExecuteQuery( "SELECT max_row from outer_site_set WHERE title='粉絲推薦'") maxrow = 1 for c in records: maxrow = c['max_row'] records = ExecuteQuery("""SELECT theme_type, mapping_id, IFNULL(ifnull(ifnull(_hcase.caption,_hcolumn.ctitle),_hproduct.name),_hvideo.title) caption , IFNULL(ifnull(_hcase.cover,_hcolumn.clogo),_hproduct.cover) J, iframe , IFNULL(ifnull(ifnull(_hcase.short_desc,_hcolumn.cdesc),_hproduct.descr),_hvideo.`desc`) short_desc , (case when theme_type='case' then CONCAT('https://hhh.com.tw/cases/detail/d/',mapping_id) when theme_type='column' then CONCAT('https://hhh.com.tw/columns/detail/',mapping_id) when theme_type='product' then CONCAT('https://hhh.com.tw/product-post.php?id=',mapping_id) when theme_type='video' then CONCAT('https://hhh.com.tw/video-post.php?id=',mapping_id) ELSE '' END) url -- SELECT * FROM homepage_set left join _hcase ON _hcase.hcase_id=homepage_set.mapping_id AND theme_type='case'-- AND _hcase.onoff = '1' LEFT JOIN _hproduct ON mapping_id = _hproduct.id AND theme_type='product'-- AND _hproduct.onoff = '1' LEFT JOIN _hcolumn ON mapping_id = _hcolumn.hcolumn_id AND theme_type='column'-- AND _hcolumn.onoff = '1' LEFT JOIN _hvideo ON mapping_id = _hvideo.hvideo_id AND theme_type='video' WHERE homepage_set.onoff='Y' AND outer_set = (SELECT oss_id from outer_site_set WHERE title='粉絲推薦') AND(NOW() BETWEEN homepage_set.start_time AND homepage_set.end_time OR(homepage_set.start_time='0000-00-00 00:00:00' and homepage_set.end_time='0000-00-00 00:00:00') or (homepage_set.start_time is null and homepage_set.end_time is NULL)) ORDER BY outer_set, inner_sort LIMIT """ + str(maxrow)) x["data"] = [] for c in records: if c['iframe'] is None: if isinstance(c['J'], bytearray) or isinstance(c['J'], bytes): c['J'] = c['J'].decode('utf8') if isinstance(c['caption'], bytearray) or isinstance(c['caption'], bytes): c['caption'] = c['caption'].decode('utf8') if isinstance(c['short_desc'], bytearray) or isinstance(c['short_desc'], bytes): c['short_desc'] = c['short_desc'].decode('utf8') a = {'imgUrl': c['J'], 'link': c['url'], 'title': c['caption'], 'description': c['short_desc'], 'video': 'false'} else: tid = extract.video_id(str(c['iframe'])) timg = "https://img.youtube.com/vi/" + tid+"/hqdefault.jpg" ccaption = "" cdescription = "" if isinstance(c['caption'], bytearray): ccaption = str(c['caption'].decode('utf8')) else: ccaption = str(c['caption']) if c['short_desc'] is not None: if isinstance(c['short_desc'], bytes): cdescription = str(c['short_desc'].decode('utf8')) else: cdescription = str(c['short_desc']) a = {'imgUrl': timg, 'link': c['url'], 'title': ccaption, 'description': cdescription, 'video': tid} x["data"].append(a) # print(x["data"]) if x['id'] == 9: records = ExecuteQuery( "SELECT id, (case when youtube_title = '' OR youtube_title IS NULL then (SELECT title FROM _hvideo ORDER BY hvideo_id DESC LIMIT 1) ELSE youtube_title END) T, (case when youtube_id = '' OR youtube_id IS NULL then (SELECT iframe FROM _hvideo ORDER BY hvideo_id DESC LIMIT 1) ELSE youtube_id end) Y FROM site_setup") for c in records: x['title'] = "" if isinstance(c['T'], bytearray): x['title'] = str(c['T'].decode('utf8')) else: x['title'] = str(c['T']) x['yt'] = extract.video_id(str(c['Y'])) # print(id) if x['id'] == 10: records = ExecuteQuery( "SELECT all_search_tag ast FROM site_setup") x["data"] = [] for c in records: x["data"] = c['ast'].split(',') # print(id) # print(jData) """ if not os.path.exists(hhhMBPath): os.mkdir(hhhMBPath) with open(hhhMBPath+'/json/' + filename, 'w', encoding='utf-8') as f: json.dump(jData, f, ensure_ascii=False, indent=4) if not os.path.exists(hhhPCPath): os.mkdir(hhhPCPath) with open(hhhPCPath+'/json/' + filename, 'w', encoding='utf-8') as f: json.dump(jData, f, ensure_ascii=False, indent=4) """ return jData @app.get("/gendesigner_list_six") def gendesigner_list_six(sort: str = "new", page: str="1",city: str = "0", county: str="0",region:str="0",dtype:str="0",dstyle:str="0",budget:str="0",arch:str="0",award:str="0",agent:str="0"): #jData = json.load(open(hhhMBPath+'/json/designer_list_all.json', encoding='utf8')) condition = "" if city != "0": condition+=""" and (t2.address like '%"""+city+"""%' or t3.address like '%"""+city+"""%') """ if county != "0": condition+=""" and (t2.address like '%"""+county+"""%' or t3.address like '%"""+county+"""%') """ if region != "0": condition+=""" and (t2.region like '%"""+region+"""%' or t2.region like '%不限%') """ if dtype != "0": condition+=""" and (t2.type like '%"""+dtype+"""%' or t2.type like '%不限%') """ if dstyle != "0": condition+=""" and (t2.style like '%"""+dstyle+"""%' or t2.style like '%不限%') """ if arch != "0": condition+=""" and license!='' """ if award !="0": condition+=""" and (t2.awards like '%亞洲設計獎%') """ if agent !="0": condition+=""" and (t2.guarantee > 0) """ if budget!="0": if budget==1: condition+=""" and (t2.min_budget>=0 and t2.min_budget<=1000000) """ elif budget==2: condition+=""" and (t2.min_budget>=1000001 and t2.min_budget<=2000000) """ elif budget==3: condition+=""" and (t2.min_budget>=2000001 and t2.min_budget<=3000000) """ elif budget==4: condition+=""" and (t2.min_budget>=3000001 and t2.min_budget<=4000000) """ elif budget==5: condition+=""" and (t2.min_budget>=4000001 and t2.min_budget<=5000000) """ elif budget==6: condition+=""" and (t2.min_budget>=5000001)""" #jData = json.load(open(hhhMBPath+'/json/designer_list_six.json', encoding='utf8')) if condition=="": if page=="1": # records = db.query("""SELECT d.hdesigner_id,d.img_path,d.title,d.name,(select c.cover from _hcase c where c.hdesigner_id = d.hdesigner_id and c.onoff=1 ORDER BY c.corder ASC ,c.viewed DESC limit 1 ) as cover FROM _hdesigner d left join xoops.designer_branch b on b.designer_id = d.hdesigner_id left join xoops._hawards ha on ha.hdesigner_id = d.hdesigner_id where ha.onoff=1 and d.top="O" GROUP BY d.hdesigner_id Order By rand(); """) records = db.query("""SELECT t2.hdesigner_id,t2.img_path,t2.name,t2.title,(SELECT t1.cover from _hcase t1 where t1.hdesigner_id = t2.hdesigner_id and t1.onoff=1 ORDER BY t1.corder ASC ,t1.viewed DESC limit 1 ) as cover FROM _hdesigner t2 left JOIN _hcase t1 on t1.hdesigner_id=t2.hdesigner_id left JOIN designer_branch t3 on t1.hdesigner_id=t3.designer_id where t2.onoff=1 and t2.top_six="O" GROUP BY t2.hdesigner_id Order By rand(); """) else: records = db.query("""SELECT t2.hdesigner_id,t2.img_path,t2.name,t2.title,(SELECT t1.cover from _hcase t1 where t1.hdesigner_id = t2.hdesigner_id and t1.onoff=1 ORDER BY t1.corder ASC ,t1.viewed DESC limit 1 ) as cover FROM _hdesigner t2 left JOIN _hcase t1 on t1.hdesigner_id=t2.hdesigner_id left JOIN designer_branch t3 on t1.hdesigner_id=t3.designer_id where t2.onoff=1 and t2.top_six!="O" GROUP BY t2.hdesigner_id Order By"""+" "+("t1.sdate" if sort == 'new' else 't1.viewed')+""" DESC LIMIT"""+" "+str((int(page) - 2)*18+12)+""" ,6;""") else: records = db.query("""SELECT t2.hdesigner_id,t2.img_path,t2.name,t2.title,(SELECT t1.cover from _hcase t1 where t1.hdesigner_id = t2.hdesigner_id and t1.onoff=1 ORDER BY t1.corder ASC ,t1.viewed DESC limit 1 ) as cover FROM _hdesigner t2 left JOIN _hcase t1 on t1.hdesigner_id=t2.hdesigner_id left JOIN designer_branch t3 on t1.hdesigner_id=t3.designer_id where t2.onoff=1 """+condition+""" GROUP BY t2.hdesigner_id Order By """+" "+("t1.sdate" if sort == 'new' else 't1.viewed')+""" DESC LIMIT"""+" "+str((int(page) - 1)*18)+""" ,6;""") #print(records) #print(jData) jData = [] for c in records: if "_hcase_img" in c["cover"]: cover=c["cover"].replace("_hcase_img","_hcase_img_orig") else: cover=c["cover"].replace("_hcase","_hcase_orig") jData.append({"hdesigner_id":str(c["hdesigner_id"]),"img_path":str(c["img_path"]),"name":c["name"],"title":c["title"],"cover":cover} ) #for x,c in zip(jData,records): # x["hdesigner_id"] = str(c["hdesigner_id"]) # x["img_path"] = str(c["img_path"]) # x["name"] = c["name"] # x["title"] = c["title"] # x["cover"] = c["cover"] return jData @app.get("/gendesigner_list_twelve") def gendesigner_list_twelve(sort: str = "new", page: str="1",city: str = "0", county: str="0",region:str="0",dtype:str="0",dstyle:str="0",budget:str="0",arch:str="0",award:str="0",agent:str="0"): #jData = json.load(open(hhhMBPath+'/json/designer_list_twelve.json', encoding='utf8')) condition = "" if city != "0": condition+=""" and (t2.address like '%"""+city+"""%' or t3.address like '%"""+city+"""%') """ if county != "0": condition+=""" and (t2.address like '%"""+county+"""%' or t3.address like '%"""+county+"""%') """ if region != "0": condition+=""" and (t2.region like '%"""+region+"""%' or t2.region like '%不限%') """ if dtype != "0": condition+=""" and (t2.type like '%"""+dtype+"""%' or t2.type like '%不限%') """ if dstyle != "0": condition+=""" and (t2.style like '%"""+dstyle+"""%' or t2.style like '%不限%') """ if arch != "0": condition+=""" and license!='' """ if award !="0": condition+=""" and (t2.awards like '%亞洲設計獎%') """ if agent !="0": condition+=""" and (t2.guarantee > 0) """ if budget!="0": if budget==1: condition+=""" and (t2.min_budget>=0 and t2.min_budget<=1000000) """ elif budget==2: condition+=""" and (t2.min_budget>=1000001 and t2.min_budget<=2000000) """ elif budget==3: condition+=""" and (t2.min_budget>=2000001 and t2.min_budget<=3000000) """ elif budget==4: condition+=""" and (t2.min_budget>=3000001 and t2.min_budget<=4000000) """ elif budget==5: condition+=""" and (t2.min_budget>=4000001 and t2.min_budget<=5000000) """ elif budget==6: condition+=""" and (t2.min_budget>=5000001)""" if condition=="": records = db.query("""SELECT t2.hdesigner_id,t2.img_path,t2.name,t2.title,(SELECT t1.cover from _hcase t1 where t1.hdesigner_id = t2.hdesigner_id and t1.onoff=1 ORDER BY t1.corder ASC ,t1.viewed DESC limit 1 ) as cover FROM _hdesigner t2 left JOIN _hcase t1 on t1.hdesigner_id=t2.hdesigner_id left JOIN designer_branch t3 on t1.hdesigner_id=t3.designer_id where t2.onoff=1 and t2.top_six!="O" GROUP BY t2.hdesigner_id Order By"""+" "+("t1.sdate" if sort == 'new' else 't1.viewed')+""" DESC LIMIT"""+" "+str((int(page)-1)*18)+""" ,12;""") else: records = db.query("""SELECT t2.hdesigner_id,t2.img_path,t2.name,t2.title,(SELECT t1.cover from _hcase t1 where t1.hdesigner_id = t2.hdesigner_id and t1.onoff=1 ORDER BY t1.corder ASC ,t1.viewed DESC limit 1 ) as cover FROM _hdesigner t2 left JOIN _hcase t1 on t1.hdesigner_id=t2.hdesigner_id left JOIN designer_branch t3 on t1.hdesigner_id=t3.designer_id where t2.onoff=1 """+condition+""" GROUP BY t2.hdesigner_id Order By"""+" "+("t1.sdate" if sort == 'new' else 't1.viewed')+""" DESC LIMIT"""+" "+str((int(page)-1)*18+6)+""" ,12;""") #print(records) #print(jData) #for x,c in zip(jData,records): # x["hdesigner_id"] = str(c["hdesigner_id"]) # x["img_path"] = str(c["img_path"]) # x["name"] = c["name"] # x["title"] = c["title"] # x["cover"] = c["cover"] jData = [] for c in records: if "_hcase_img" in c["cover"]: cover=c["cover"].replace("_hcase_img","_hcase_img_orig") else: cover=c["cover"].replace("_hcase","_hcase_orig") jData.append({"hdesigner_id":str(c["hdesigner_id"]),"img_path":str(c["img_path"]),"name":c["name"],"title":c["title"],"cover":cover} ) return jData @app.get("/gendesigner_list_all") def gendesigner_list_all(city: str = "0", county: str="0",region:str="0",dtype:str="0",dstyle:str="0",budget:str="0",arch:str="0",award:str="0",agent:str="0"): #jData = json.load(open(hhhMBPath+'/json/designer_list_all.json', encoding='utf8')) condition = "" if city != "0": condition+=""" and (t2.address like '%"""+city+"""%' or t3.address like '%"""+city+"""%') """ if county != "0": condition+=""" and (t2.address like '%"""+county+"""%' or t3.address like '%"""+county+"""%') """ if region != "0": condition+=""" and (t2.region like '%"""+region+"""%' or t2.region like '%不限%') """ if dtype != "0": condition+=""" and (t2.type like '%"""+dtype+"""%' or t2.type like '%不限%') """ if dstyle != "0": condition+=""" and (t2.style like '%"""+dstyle+"""%' or t2.style like '%不限%') """ if arch != "0": condition+=""" and license!='' """ if award !="0": condition+=""" and (t2.awards like '%亞洲設計獎%') """ if agent !="0": condition+=""" and (t2.guarantee > 0) """ if budget!="0": if budget==1: condition+=""" and (t2.min_budget>=0 and t2.min_budget<=1000000) """ elif budget==2: condition+=""" and (t2.min_budget>=1000001 and t2.min_budget<=2000000) """ elif budget==3: condition+=""" and (t2.min_budget>=2000001 and t2.min_budget<=3000000) """ elif budget==4: condition+=""" and (t2.min_budget>=3000001 and t2.min_budget<=4000000) """ elif budget==5: condition+=""" and (t2.min_budget>=4000001 and t2.min_budget<=5000000) """ elif budget==6: condition+=""" and (t2.min_budget>=5000001)""" records = db.query("""SELECT t2.hdesigner_id,t2.img_path,t2.name,t2.title,(SELECT t1.cover from _hcase t1 where t1.hdesigner_id = t2.hdesigner_id and t1.onoff=1 ORDER BY t1.corder ASC ,t1.viewed DESC limit 1 ) as cover FROM _hdesigner t2 left JOIN _hcase t1 on t1.hdesigner_id=t2.hdesigner_id left JOIN designer_branch t3 on t1.hdesigner_id=t3.designer_id where t2.onoff=1 """+condition+""" GROUP BY t2.hdesigner_id;""") #print(records) #print(jData) jData = [] for c in records: if "_hcase_img" in c["cover"]: cover=c["cover"].replace("_hcase_img","_hcase_img_orig") else: cover=c["cover"].replace("_hcase","_hcase_orig") jData.append({"hdesigner_id":str(c["hdesigner_id"]),"img_path":str(c["img_path"]),"name":c["name"],"title":c["title"],"cover":c["cover"]} ) json.dumps(jData) #print(jData) #print(len(jData)) return jData @app.get("/find_designer_show") def find_designer_show(cid:str ,type_use: str="computer"): condition = "" #jData = json.load(open(hhhMBPath+'/json/designer_list_all.json', encoding='utf8')) if type_use == "computer": records = db.query("""SELECT order_computer FROM _hdesigner where hdesigner_id="""+cid+""";""") jData = [] for c in records: jData.append({"order_show_type":str(c["order_computer"])} ) json.dumps(jData) else: records = db.query("""SELECT order_mb FROM _hdesigner where hdesigner_id="""+cid+""";""") jData = [] for c in records: jData.append({"order_show_type":str(c["order_mb"])} ) json.dumps(jData) #print(records) #print(jData) #print(jData) #print(len(jData)) return jData @app.get("/find_total") def find_total(cid:str ,type_use: str): condition = "" if type_use=='case': #jData = json.load(open(hhhMBPath+'/json/designer_list_all.json', encoding='utf8')) records = db.query("""SELECT count(*) FROM _hcase c WHERE c.hdesigner_id = '""" + cid + """' AND c.onoff='1'; """ ) elif type_use=='video': records = db.query("""SELECT count(*) FROM _hvideo v WHERE v.hdesigner_id = '""" + cid + """' AND display_datetime < NOW() ;""") elif type_use == 'column': records = db.query("""SELECT count(*) FROM _hcolumn c WHERE onoff=1 AND (c.hdesigner_ids LIKE '""" + cid + """,%' OR c.hdesigner_ids LIKE '%,""" + cid + """,%' OR c.hdesigner_ids LIKE '%,""" + cid + """' OR c.hdesigner_ids = '""" + cid + """') ;""") elif type_use == 'vr360': records = db.query("""SELECT count(*) FROM _hcase c WHERE c.hdesigner_id = '""" + cid + """' and istaging != '' AND c.onoff='1' ;""") jData = [] for c in records: jData.append({"total":str(c["count(*)"])} ) json.dumps(jData) #print(records) #print(jData) #print(jData) #print(len(jData)) return jData @app.get("/find_user_favorite") def find_user_favorite(user_id: str ,cid:str, type_use: str="designer"): condition = "" #jData = json.load(open(hhhMBPath+'/json/designer_list_all.json', encoding='utf8')) records = db.query("""SELECT * FROM user_favorite where status=0 and user_id="""+user_id+""" and table_id="""+cid+""" and type= '"""+type_use+"""' ;""") #print(records) #print(jData) jData = [] for c in records: jData.append({"id":str(c["id"]),"user_id":str(c["user_id"]),"type":c["type"],"cid":c["table_id"],"create_time":str(c["create_time"]),"status":str(c["status"])} ) json.dumps(jData) #print(jData) #print(len(jData)) return jData # @app.post("/add_user_favorite") # def add_user_favorite(user_id: str ,cid:str, type_use: str="designer"): # records = db.query("""SELECT * FROM user_favorite where status=1 and user_id="""+user_id+""" and table_id="""+cid+""" and type= '"""+type_use+"""' ;""") # jData = [] # for c in records: # jData.append({"id":str(c["id"]),"user_id":str(c["user_id"]),"type":c["type"],"cid":c["table_id"],"create_time":str(c["create_time"]),"status":str(c["status"])} ) # json.dumps(jData) # if len(jData)>0: # db.query("""UPDATE user_favorite SET status=0 WHERE user_id="""+user_id+""" and table_id="""+cid+""" and type= '"""+type_use+"""';""") # else: # records = db.query("""SELECT * FROM user_favorite where status=0 and user_id="""+user_id+""" and table_id="""+cid+""" and type= '"""+type_use+"""' ;""") # jData = [] # json.dumps(jData) # if len(jData)==0: # db.query("""INSERT INTO user_favorite (user_id, type, table_id) values ( """+user_id+""",'"""+type_use+"""',"""+cid+""");""") # db.commit() # return True # @app.post("/delete_user_favorite") # def delete_user_favorite(user_id: str ,cid:str, type_use: str="designer"): # records = db.query("""SELECT * FROM user_favorite where status=0 and user_id="""+user_id+""" and table_id="""+cid+""" and type= '"""+type_use+"""' ;""") # jData = [] # for c in records: # jData.append({"id":str(c["id"]),"user_id":str(c["user_id"]),"type":c["type"],"cid":c["table_id"],"create_time":str(c["create_time"]),"status":str(c["status"])} ) # json.dumps(jData) # if len(jData)>0: # db.query("""UPDATE user_favorite SET status=1 WHERE user_id="""+user_id+""" and table_id="""+cid+""" and type= '"""+type_use+"""';""") # return True #=================================================================================================================================== @app.get("/gencase") def gencase(id: str = "14151", sort: str = "new", page: str="1"): jData = json.load(open(hhhMBPath+'/json/cases.json', encoding='utf8')) records = db.query("""SELECT *, c.style cstyle, c.style2 cstyle2 FROM _hcase c LEFT JOIN _hdesigner d ON c.hdesigner_id = d.hdesigner_id WHERE c.hcase_id = '""" + id + """' AND c.onoff='1' AND d.onoff='1' and c.sdate < now() """) #print(jData) for x in jData: tmpCaseDetail = [] icount = 0 for c in records: icount += 1 #tmpCaseDetail.append({"CaseDetailImg": c["cimg"]}) #x["CaseDetail"] = tmpCaseDetail if c != None: x["designerid"] = str(c["hdesigner_id"]) x["CaseId"] = str(c["hcase_id"]) x["Casetitle"] = c["caption"] x["CaseTeamName"] = c["name"] x["CaseCompany"] = c["title"] x["CaseCompanyAddress"] = c["address"] x["CaseCompanyTel"] = c["phone"] x["CaseCompanyEmail"] = c["mail"] x["CaseCompanyWeb"] = c["website"] x["CaseDate"] = str(c["sdate"]) x["CaseViews"] = c["viewed"] x["CaseCoverImg"] = c["cover"] x["CaseImgAmount"] = icount x["CaseStyle"] = c["cstyle"] x["CaseHouse"] = c["layout"] x["CaseSize"] = c["area"] x["CaseProject"] = "" x["CaseDataMember"] = c["member"] x["CaseDataSize"] = c["area"] x["CaseDataStyle"] = c["cstyle"] + c["cstyle2"] x["CaseDataType"] = c["type"] x["CaseDataSituation"] = c["condition"] x["CaseDataImgProvide"] = c["provider"] x["CaseDataSpace"] = c["layout"] x["CaseDataMaterial"] = c["materials"] x["ContactFreeTel"] = c["service_phone"] x["ContactDesignerImg"] = c["img_path"] x["CasePageLink"] = "" x["CasePageprev"] = "" #x["CaseTag"]= [] #相同設計師的個案 sql = """SELECT * FROM _hcase c WHERE hdesigner_id = '""" + x["designerid"] + """' and hcase_id <> '""" + x["CaseId"] + """' and sdate < now() AND c.onoff='1' ORDER BY """ + ("sdate" if sort == 'new' else 'viewed') + """ DESC LIMIT """ + str((int(page) - 1)*12) + """,12 """ cases = db.query(sql) tmpOtherCases = [] for other in cases: tmpOtherCase = {} tmpOtherCase["designerid"] = str(other["hdesigner_id"]) tmpOtherCase["casesid"] = str(other["hcase_id"]) tmpOtherCase["Views"] = other["viewed"] tmpOtherCase["ProfileImg"] = other["cover"] tmpTags = [] for tag in other["tag"].split(','): tmpTags.append({"Tag": tag , "TagLink": "" }) tmpOtherCase["ProfileTag"] = tmpTags tmpOtherCases.append(tmpOtherCase) x["DesignerProfile"] = tmpOtherCases #相同風格的個案 sql = """SELECT * FROM _hcase c WHERE style = '""" + x["CaseStyle"] + """' and hcase_id <> '""" + x["CaseId"] + """' and sdate < now() AND c.onoff='1' ORDER BY """ + ("sdate" if sort == 'new' else 'viewed') + """ DESC LIMIT """ + str((int(page) - 1)*12) + """,12 """ cases = db.query(sql) tmpOtherCases = [] for other in cases: tmpOtherCase = {} tmpOtherCase["designerid"] = str(other["hdesigner_id"]) tmpOtherCase["casesid"] = str(other["hcase_id"]) tmpOtherCase["Views"] = other["viewed"] tmpOtherCase["ProfileImg"] = other["cover"] tmpTags = [] for tag in other["tag"].split(','): tmpTags.append({"Tag": tag , "TagLink": "" }) tmpOtherCase["ProfileTag"] = tmpTags tmpOtherCases.append(tmpOtherCase) x["StyleProfile"] = tmpOtherCases #相同風格的RANDOM 10筆 #cases = db.query("""SELECT * FROM _hcase c #WHERE style = '""" + x["CaseStyle"] + """' and hcase_id <> '""" + x["CaseId"] + """' and sdate < now() AND c.onoff='1' #ORDER BY RAND() #LIMIT 10 #""") """ tmpOtherCases = [] for other in cases: tmpOtherCase = {} tmpOtherCase["designerid"] = str(other["hdesigner_id"]) tmpOtherCase["casesid"] = str(other["hcase_id"]) tmpOtherCase["PortfoliolImg"] = other["cover"] tmpOtherCase["PortfoliolLink"] = "" tmpOtherCase["PortfoliolImgAlt"] = other["caption"] tmpOtherCases.append(tmpOtherCase) x["OtherStylePortfolio"]= tmpOtherCases """ # print(x) # print(jData) """ if not os.path.exists(hhhMBPath): os.mkdir(hhhMBPath) with open(hhhMBPath+'/json/cases-' + id + '.json', 'w', encoding='utf-8') as f: json.dump(jData, f, ensure_ascii=False, indent=4) """ return jData @app.get("/gendesigner") def gendesigner(id: str = "14151"): jData = json.load(open(hhhMBPath+'/json/designers.json', encoding='utf8')) records = db.query("""SELECT *, ci.name cimg FROM _hcase c LEFT JOIN _hcase_img ci ON c.hcase_id = ci.hcase_id LEFT JOIN _hdesigner d ON c.hdesigner_id = d.hdesigner_id WHERE d.hdesigner_id = '""" + id + """' AND c.onoff='1' AND d.onoff='1' """) # print(jData) for x in jData: tmpCaseDetail = [] icount = 0 for c in records: icount += 1 # tmpCaseDetail.append({"CaseDetailImg":c["cimg"]}) x["id"] = c["hdesigner_id"] x["BannerImg"] = c["background"] x["CompanyName"] = c["title"] x["DesignerName"] = c["name"] x["Designerimg"] = c["img_path"] x["Description"] = c["seo"] x["Approve"] = c["position"] x["Basics"] = [ {"title": "免費專線:", "link": c["service_phone"], "data": c["service_phone"]}, {"title": "諮詢專線:", "link": c["phone"], "data": c["phone"]}, {"title": "諮詢專線:", "link": c["phone"], "data": c["phone"]}, {"title": "公司傳真:", "link": c["fax"], "data": c["fax"]}, {"title": "公司地址:", "link": c["address"], "data": c["address"]}, {"title": "電子信箱:", "link": c["mail"], "data": c["mail"]}, {"title": "公司網址:", "link": c["website"], "data": c["website"]} ] x["FreeCall"] = c["service_phone"] x["ConsoleCall_1"] = c["phone"] x["ConsoleCall_2"] = c["phone"] x["Fax"] = c["fax"] x["Address"] = c["address"] x["Email"] = c["mail"] x["Web"] = c["website"] x["Branches"] = [ {"title": "分公司地址:", "link": "台北市中山區林森北路50號4樓之一", "data": "台北市中山區林森北路50號4樓之一"}, {"title": "分公司電話:", "link": "tel:02-2562-7755", "data": "02-2562-7755"}, {"title": "分公司傳真:", "link": "tel:02-2562-7002", "data": "02-2562-7002"}, {"title": "分公司地址:", "link": "上海市闵行区东川路2688号", "data": "上海市闵行区东川路2688号"} ] x["Budget"] = c["budget"] x["Square"] = c["area"] x["SpecialCase"] = c["special"] x["Charge"] = c["charge"] x["Pay"] = c["payment"] x["WorkLoc"] = c["region"] x["WorkType"] = c["type"] x["WorkStyle"] = c["style"] x["WorkBudget"] = c["budget"] x["Terms"] = [ {"title": "接案預算:", "data": c["budget"]}, {"title": "接案坪數:", "data": c["area"]}, {"title": "特殊接案:", "data": c["special"]}, {"title": "收費方式:", "data": c["charge"]}, {"title": "付費方式:", "data": c["payment"]}, {"title": "接案區域:", "data": c["region"]}, {"title": "接案類型:", "data": c["type"]}, {"title": "接案風格:", "data": c["style"]} ] x["scMedia"] = [ {"name": "Facebook", "img": "https://hhh.com.tw/assets/images/rv_web/fb.svg", "link": c["fbpageurl"]}, {"name": "Line", "img": "https://hhh.com.tw/assets/images/rv_web/line.svg", "link": c["line_link"]}, {"name": "Wechat", "img": "https://hhh.com.tw/assets/images/rv_web/wechat.svg", "link": c["fbpageurl"]}, {"name": "email", "img": "https://hhh.com.tw/assets/images/rv_web/share.svg", "link": c["mail"]}, {"name": "Like", "img": "https://hhh.com.tw/assets/images/rv_web/like-o.svg", "link": ""} ] x["Content"] = [ { "Title": "設計師作品", "mb_title": "作品", "Tabtag": "intro", "Display_mb": "true", "isActive": "true", "Carddata": [ ] }, { "Title": "設計師影音", "mb_title": "影音", "Tabtag": "video", "Display_mb": "true", "isActive": "true", "Carddata": [ ] }, { "Title": "設計師專欄", "mb_title": "專欄", "Tabtag": "columns", "Display_mb": "true", "isActive": "true", "Carddata": [ ] }, { "Title": "VR360", "mb_title": "", "Tabtag": "vr360", "Display_mb": "false", "isActive": "true", "Carddata": [ ] }, { "Title": "設計師公司簡介", "mb_title": "公司簡介", "Tabtag": "company", "Display_mb": "true", "isActive": "true", "Carddata": [ ], "info": [ {"title": "設計理念", "data": "空間設計的美學藝術,蔡岳儒總監更能將日式精闢的手工藝術融入台灣的設計與工程,更將留日所學發揚光大明確的把結構、 動線、收納、光線與品味融入建築、景觀與室內三大空間之中,藉由點線面展現出空間的獨特性,並賦予空間延續的生命活力。"}, {"title": "公司統編", "data": "經濟部/財政部登記有案:54290717"}, {"title": "相關經歷", "data": "蔡岳儒
◆現任/恆岳空間設計 主持設計師
◆學歷/東京デザイナー学院卒業
◆經歷/十餘年設計、工程經歷。"}, {"title": "專業證照", "data": "建築師證書 高恒悌 (101) 專高建字第000013號
建築物室內裝修專業技術人員登記證 高恒悌 第40EC116787號"}, {"title": "獲獎紀錄", "data": "2020年雪梨設計獎SYDNEY Design Awards GIOD-Quality Arena
2020年雪梨設計獎SYDNEY Design Awards SELECTION- Life Savoring"} ] } ] # print(x) # print(jData) """ if not os.path.exists(hhhMBPath): os.mkdir(hhhMBPath) with open(hhhMBPath+'/json/designers-' + id + '.json', 'w', encoding='utf-8') as f: json.dump(jData, f, ensure_ascii=False, indent=4) """ return jData @app.get("/gencolumn") def gencolumn(id: str = "6392", sort: str = "new", page: str="1"): jData = json.load(open(hhhMBPath+'/json/Columns.json', encoding='utf8')) records = db.query("""SELECT * FROM _hcolumn c WHERE c.hcolumn_id = '""" + id + """' AND c.onoff='1' """) #print(id) for x in jData: icount = 0 c = None for c in records: icount += 1 if c != None: x["Columnsid"] = str(c["hcolumn_id"]) x["Columnstitle"] = c["ctitle"] x["ColumnsCoverImg"] = c["clogo"] x["ColumnsDate"] = str(c["sdate"]) x["ColumnsViews"] = str(c["viewed"]) if page == "1": x["ColumnsContent"] = c["page_content"] tmpTags = [] for tag in c["ctag"].split(','): tmpTags.append({"Tag": tag}) x["ColumnsTag"] = tmpTags x["author_inf"] = c["extend_str"] #相同類別的最新12筆 sql = """SELECT * FROM _hcolumn c WHERE (c.ctype like '%""" + str(c["ctype"]) + """%' and c.ctype_sub like '%""" + str(c["ctype_sub"]) + """%') and hcolumn_id <> '""" + str(c["hcolumn_id"]) + """' and sdate < now() AND c.onoff='1' ORDER BY """ + ("sdate" if sort == 'new' else 'viewed') + """ DESC LIMIT """ + str((int(page) - 1)*12) + """,12 """ ctypes = db.query(sql) tmpOtherCols = [] for other in ctypes: tmpOtherCol = {} tmpOtherCol["Columnsid"] = str(other["hcolumn_id"]) tmpOtherCol["ColumnsCoverImg"] = other["clogo"] tmpOtherCol["Views"] = other["viewed"] tmpOtherCol["Columnstitle"] = other["ctitle"] tmpTags = [] for tag in other["ctag"].split(','): tmpTags.append({"Tag": tag}) tmpOtherCol["ColumnsTag"] = tmpTags tmpOtherCols.append(tmpOtherCol) x["OtherColumns"] = tmpOtherCols #print(x) # print(jData) """ if not os.path.exists(hhhMBPath): os.mkdir(hhhMBPath) with open(hhhMBPath+'/json/Columns-' + id + '.json', 'w', encoding='utf-8') as f: json.dump(jData, f, ensure_ascii=False, indent=4) """ return jData @app.get("/getColumnAds") def getColumnAds(): ads = [] records = db.query("""SELECT adlogo_mobile imgUrl, adlogo DimgUrl, adhref link FROM _had hh WHERE adtype LIKE '專欄首大%' AND hh.onoff='1' and NOW() BETWEEN start_time AND end_time ORDER BY cast(SUBSTR(adtype, 4) AS DECIMAL) """) """ for x in records: ads.append(x) """ ads.extend(records) rData = json.loads(json.dumps(ads)) #print(json.dumps(ads)) return rData """ if __name__ == "__main__": uvicorn.run(app, host="0.0.0.0", port=8000) """