MoneyRadar / app.py
seawolf2357's picture
Update app.py
638a422 verified
raw
history blame
3.98 kB
import gradio as gr
import requests
import json
from datetime import datetime, timedelta
import pandas as pd
API_KEY = "V38CNn4HXpLtynJQyOeoUensTEYoFy8PBUxKpDqAW1pawT1vfJ2BWtPQ98h6"
MAJOR_COUNTRIES = [
"United States", "United Kingdom", "Canada", "Australia", "Germany",
"France", "Japan", "South Korea", "China", "India",
"Brazil", "Mexico", "Russia", "Italy", "Spain",
"Netherlands", "Sweden", "Switzerland", "Norway", "Denmark",
"Finland", "Belgium", "Austria", "New Zealand", "Ireland",
"Singapore", "Hong Kong", "Israel", "United Arab Emirates", "Saudi Arabia",
"South Africa", "Turkey", "Egypt", "Poland", "Czech Republic",
"Hungary", "Greece", "Portugal", "Argentina", "Chile",
"Colombia", "Peru", "Venezuela", "Thailand", "Malaysia",
"Indonesia", "Philippines", "Vietnam", "Pakistan", "Bangladesh"
]
def search_serphouse(query, country, page, num_result):
url = "https://api.serphouse.com/serp/live"
now = datetime.utcnow()
yesterday = now - timedelta(days=1)
date_range = f"{yesterday.strftime('%Y-%m-%d')},{now.strftime('%Y-%m-%d')}"
payload = {
"data": {
"q": query,
"domain": "google.com",
"loc": country,
"lang": "en",
"device": "desktop",
"serp_type": "news",
"page": str(page),
"verbatim": "1",
"num": str(num_result),
"date_range": date_range
}
}
headers = {
"accept": "application/json",
"content-type": "application/json",
"authorization": f"Bearer {API_KEY}"
}
try:
response = requests.post(url, json=payload, headers=headers)
response.raise_for_status()
return response.json()
except requests.RequestException as e:
error_msg = f"Error: {str(e)}"
if response.text:
error_msg += f"\nResponse content: {response.text}"
return {"error": error_msg}
def format_results(results):
if isinstance(results, dict) and "error" in results:
return pd.DataFrame({"Error": [results["error"]]})
try:
if not isinstance(results, dict):
raise ValueError("κ²°κ³Όκ°€ 사전 ν˜•μ‹μ΄ μ•„λ‹™λ‹ˆλ‹€.")
if "results" not in results:
raise ValueError("'results' ν‚€κ°€ 응닡에 μ—†μŠ΅λ‹ˆλ‹€.")
news_results = results["results"].get("news", [])
if not news_results:
return pd.DataFrame({"Message": ["검색 κ²°κ³Όκ°€ μ—†μŠ΅λ‹ˆλ‹€."]})
formatted_results = []
for result in news_results:
formatted_results.append({
"제λͺ©": result.get("title", "제λͺ© μ—†μŒ"),
"링크": result.get("url", "#"),
"λ‚΄μš©": result.get("snippet", "λ‚΄μš© μ—†μŒ"),
"좜처": result.get("channel", "μ•Œ 수 μ—†μŒ"),
"μ‹œκ°„": result.get("time", "μ•Œ 수 μ—†λŠ” μ‹œκ°„")
})
return pd.DataFrame(formatted_results)
except Exception as e:
return pd.DataFrame({"Error": [f"κ²°κ³Ό 처리 쀑 였λ₯˜ λ°œμƒ: {str(e)}"]})
def serphouse_search(query, country, page, num_result):
results = search_serphouse(query, country, page, num_result)
return format_results(results)
css = """
footer {
visibility: hidden;
}
"""
iface = gr.Interface(
fn=serphouse_search,
inputs=[
gr.Textbox(label="검색어"),
gr.Dropdown(MAJOR_COUNTRIES, label="κ΅­κ°€"),
gr.Slider(1, 10, 1, label="νŽ˜μ΄μ§€"),
gr.Slider(1, 100, 10, label="결과 수")
],
outputs=gr.Dataframe(label="λ‰΄μŠ€ κ²°κ³Ό"),
title="24μ‹œκ°„ 이내 λ‰΄μŠ€ 검색 μΈν„°νŽ˜μ΄μŠ€",
description="검색어λ₯Ό μž…λ ₯ν•˜κ³  κ΅­κ°€λ₯Ό μ„ νƒν•˜μ—¬ 24μ‹œκ°„ μ΄λ‚΄μ˜ λ‰΄μŠ€ κ²°κ³Όλ₯Ό κ°€μ Έμ˜΅λ‹ˆλ‹€.",
theme="Nymbo/Nymbo_Theme",
css=css
)
iface.launch(auth=("gini","pick"))