Spaces:
Running
Running
File size: 3,978 Bytes
f2842d4 1ee305b 638a422 f2842d4 1ee305b f4723df f2842d4 1ee305b f4723df f2842d4 4e396cb f2842d4 4e396cb 638a422 f2842d4 4e396cb 638a422 e63a0fd 638a422 e63a0fd 638a422 1ee305b f2842d4 638a422 f2842d4 e63a0fd f2842d4 638a422 4e396cb f2842d4 7711b03 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 |
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")) |