jimmy624135 commited on
Commit
6632464
·
verified ·
1 Parent(s): a431156

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +108 -0
app.py ADDED
@@ -0,0 +1,108 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import os
2
+ import requests
3
+ import pandas as pd
4
+ import matplotlib as mpl
5
+ import matplotlib.font_manager as fm
6
+ import matplotlib.pyplot as plt
7
+ import streamlit as st
8
+ import time
9
+ import json
10
+ from io import BytesIO
11
+
12
+ # Streamlit app title
13
+ st.title("MOMO & PCHOME 商品搜索和價格分析")
14
+
15
+ # 從使用者獲取搜索關鍵字和頁數
16
+ search_keyword = st.text_input("請輸入要搜索的關鍵字: ", "筆電")
17
+ page_number = st.number_input("請輸入要搜索的頁數: ", min_value=1, max_value=100, value=1, step=1)
18
+
19
+ # 如果用戶輸入了搜索關鍵字
20
+ if st.button("抓取並分析"):
21
+ # MOMO 数据抓取
22
+ momo_url = "https://apisearch.momoshop.com.tw/momoSearchCloud/moec/textSearch"
23
+ momo_headers = {
24
+ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/127.0.0.0 Safari/537.36"
25
+ }
26
+ momo_payload = {
27
+ "host": "momoshop",
28
+ "flag": "searchEngine",
29
+ "data": {
30
+ "searchValue": search_keyword,
31
+ "curPage": str(page_number),
32
+ "priceS": "0",
33
+ "priceE": "9999999",
34
+ "searchType": "1"
35
+ }
36
+ }
37
+ momo_response = requests.post(momo_url, headers=momo_headers, json=momo_payload)
38
+
39
+ if momo_response.status_code == 200:
40
+ momo_data = momo_response.json().get('rtnSearchData', {}).get('goodsInfoList', [])
41
+ momo_products = []
42
+ for product in momo_data:
43
+ name = product.get('goodsName', '')
44
+ price = product.get('goodsPrice', '')
45
+ price_str = str(price).split('(')[0].replace(',', '').replace('$', '')
46
+ try:
47
+ product_price = float(price_str)
48
+ except ValueError:
49
+ product_price = 0
50
+ momo_products.append({'title': name, 'price': product_price})
51
+ momo_df = pd.DataFrame(momo_products)
52
+ st.write("MOMO 商品數據:", momo_df)
53
+ else:
54
+ st.error(f"MOMO 請求失敗,狀態碼: {momo_response.status_code}")
55
+
56
+ # PCHOME 数据抓取
57
+ pchome_url = f'https://ecshweb.pchome.com.tw/search/v3.3/all/results?q={search_keyword}&page={page_number}&sort=sale/dc'
58
+ pchome_response = requests.get(pchome_url)
59
+
60
+ if pchome_response.status_code == 200:
61
+ pchome_data = json.loads(pchome_response.content).get('prods', [])
62
+ pchome_df = pd.DataFrame(pchome_data)[["name", "price"]]
63
+ st.write("PCHOME 商品數據:", pchome_df)
64
+ else:
65
+ st.error(f"PCHOME 請求失敗,狀態碼: {pchome_response.status_code}")
66
+
67
+ # 數據分析和視覺化
68
+ if not momo_df.empty:
69
+ momo_avg_price = momo_df['price'].mean()
70
+ st.write(f"MOMO 平均價格: {momo_avg_price:.2f}")
71
+ st.write(f"MOMO 最高價格: {momo_df['price'].max():.2f}")
72
+ st.write(f"MOMO 最低價格: {momo_df['price'].min():.2f}")
73
+
74
+ if not pchome_df.empty:
75
+ pchome_avg_price = pchome_df['price'].mean()
76
+ st.write(f"PCHOME 平均價格: {pchome_avg_price:.2f}")
77
+ st.write(f"PCHOME 最高價格: {pchome_df['price'].max():.2f}")
78
+ st.write(f"PCHOME 最低價格: {pchome_df['price'].min():.2f}")
79
+
80
+ # 字型設定
81
+ font_url = "https://drive.google.com/uc?id=1eGAsTN1HBpJAkeVM57_C7ccp7hbgSz3_&export=download"
82
+ font_response = requests.get(font_url)
83
+ with open("TaipeiSansTCBeta-Regular.ttf", "wb") as font_file:
84
+ font_file.write(font_response.content)
85
+ fm.fontManager.addfont("TaipeiSansTCBeta-Regular.ttf")
86
+ mpl.rc('font', family='Taipei Sans TC Beta')
87
+
88
+ # MOMO 繪製價格折線圖
89
+ if not momo_df.empty:
90
+ fig_momo, ax_momo = plt.subplots(figsize=(15, 8))
91
+ momo_df['price'][:70].plot(ax=ax_momo, marker='o', linestyle='-', color='skyblue', linewidth=2, markersize=8)
92
+ plt.title(f'MOMO 電商網站上 "{search_keyword}" 的銷售價格', fontsize=20, fontweight='bold', color='navy')
93
+ plt.axhline(y=momo_avg_price, color='red', linestyle='--', linewidth=2, label=f'參考價格: {momo_avg_price:.2f}')
94
+ plt.legend(fontsize=12, loc='upper left')
95
+ plt.grid(axis='y', linestyle='--', alpha=0.5)
96
+ plt.tight_layout()
97
+ st.pyplot(fig_momo)
98
+
99
+ # PCHOME 繪製價格折線圖
100
+ if not pchome_df.empty:
101
+ fig_pchome, ax_pchome = plt.subplots(figsize=(15, 8))
102
+ pchome_df['price'][:70].plot(ax=ax_pchome, marker='o', linestyle='-', color='skyblue', linewidth=2, markersize=8)
103
+ plt.title(f'PCHOME 電商網站上 "{search_keyword}" 的銷售價格', fontsize=20, fontweight='bold', color='navy')
104
+ plt.axhline(y=pchome_avg_price, color='red', linestyle='--', linewidth=2, label=f'參考價格: {pchome_avg_price:.2f}')
105
+ plt.legend(fontsize=12, loc='upper left')
106
+ plt.grid(axis='y', linestyle='--', alpha=0.5)
107
+ plt.tight_layout()
108
+ st.pyplot(fig_pchome)