Spaces:
Sleeping
Sleeping
File size: 3,415 Bytes
bcabae3 9b5b26a c19d193 6aae614 9b5b26a c92d5f8 1552bf5 bcabae3 dade8b2 bcabae3 c92d5f8 9b5b26a c92d5f8 bcabae3 c92d5f8 9b5b26a bcabae3 c92d5f8 bcabae3 c92d5f8 bcabae3 c92d5f8 bcabae3 c92d5f8 bcabae3 c92d5f8 bcabae3 c92d5f8 9b5b26a 8c01ffb 6aae614 ae7a494 e121372 bcabae3 13d500a 8c01ffb 9b5b26a 8c01ffb 861422e bcabae3 8c01ffb 8fe992b bcabae3 8c01ffb 861422e 8fe992b 8c01ffb |
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 |
from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool
from Gradio_UI import GradioUI
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Service
from webdriver_manager.chrome import ChromeDriverManager
@tool
def get_zh_top_news() -> tuple[str, str]:
"""A tool that retrieves the current top news article's title and URL from www.zerohedge.com.
Returns:
tuple[str, str]: A tuple containing the article title (str) and its URL (str).
Raises:
Exception: If the page fails to load or the expected element is not found.
"""
# Set up Chrome options for headless browsing
chrome_options = Options()
chrome_options.add_argument("--headless") # Run without opening a browser window
chrome_options.add_argument("--disable-gpu") # Disable GPU for headless mode
chrome_options.add_argument("--no-sandbox") # Required for containerized environments
chrome_options.add_argument("--disable-dev-shm-usage") # Avoid memory issues in containers
# Use webdriver-manager to automatically manage ChromeDriver
driver = webdriver.Chrome(service=Service(ChromeDriverManager().install()), options=chrome_options)
try:
# Navigate to ZeroHedge homepage
driver.get("https://www.zerohedge.com")
# Find the top article element using a CSS selector
top_article = driver.find_element(By.CSS_SELECTOR, "article .ArticleTeaser_titleLink__mK4rX")
# Extract the title and URL
article_title = top_article.text.strip()
article_link = top_article.get_attribute("href")
# Ensure the link is absolute
if not article_link.startswith("http"):
article_link = f"https://www.zerohedge.com{article_link}"
return article_title, article_link
except Exception as e:
print(f"Error retrieving top headline: {e}")
return "Error: Headline not found", "https://www.zerohedge.com"
finally:
driver.quit()
@tool
def get_current_time_in_timezone(timezone: str) -> str:
"""A tool that fetches the current local time in a specified timezone.
Args:
timezone: A string representing a valid timezone (e.g., 'America/New_York').
"""
try:
tz = pytz.timezone(timezone)
local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
return f"The current local time in {timezone} is: {local_time}"
except Exception as e:
return f"Error fetching time for timezone '{timezone}': {str(e)}"
final_answer = FinalAnswerTool()
model = HfApiModel(
max_tokens=2096,
temperature=0.5,
model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
custom_role_conversions=None,
)
image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
with open("prompts.yaml", 'r') as stream:
prompt_templates = yaml.safe_load(stream)
agent = CodeAgent(
model=model,
tools=[get_zh_top_news, get_current_time_in_timezone, final_answer],
max_steps=6,
verbosity_level=1,
grammar=None,
planning_interval=None,
name=None,
description=None,
prompt_templates=prompt_templates
)
GradioUI(agent).launch() |