APRG's picture
Update tools.py
71c08fb verified
from smolagents import DuckDuckGoSearchTool
from smolagents import Tool
import random
from huggingface_hub import list_models
import requests
from bs4 import BeautifulSoup
import openpyxl
import wikipedia
import pandas as pd
class MediaTool(Tool):
name = "media_tool"
description = "Used for deciphering video and audio files."
inputs = {
"filename": {
"type": "string",
"description": "The name of the media file to transcribe."
}
}
output_type = "string"
def forward(self, filename: str):
print(f"called MediaTool with {filename}")
return "This tool hasn't been implemented yet. Please return 0 if the task cannot be solved without knowing the contents of this file."
class WikipediaTool(Tool):
name = "wikipedia_api"
description = "Returns the contents of a wikipedia article through a direct API call."
inputs = {
"title": {
"type": "string",
"description": "The title of the wikipedia article to retrieve."
}
}
output_type = "string"
def forward(self, title: str):
print(f"called WikipediaTool with {title}")
try:
page = wikipedia.page(title)
content = page.content[:3000]
return content
except Exception as e:
return f"ERROR: {e}"
class ExcelTool(Tool):
name = "read_excel"
description = "Returns the contents of an Excel file as a Pandas dataframe."
inputs = {
"filename": {
"type": "string",
"description": "The name of the Excel file to read."
}
}
output_type = "string"
def forward(self, filename: str):
print(f"called ExcelTool with {filename}")
try:
df = pd.read_excel(filename, engine = "openpyxl")
return df
except Exception as e:
return f"ERROR: {e}"
class WebscraperTool(Tool):
name = "webscraper"
description = "Returns the page's html content from the input url."
inputs = {
"url": {
"type": "string",
"description": "The link of the web page to scrape."
}
}
output_type = "string"
def forward(self, url: str):
print(f"called WebscraperTool with {url}")
try:
response = requests.get(url, stream=True)
if response.status_code == 200:
soup = BeautifulSoup(response.content, 'html.parser')
html_text = soup.get_text()
return html_text
else:
return "Website cannot be reached."
except Exception as e:
return f"ERROR: {e}"
# Initialize the DuckDuckGo search tool
class InternetSearchTool(Tool):
name = "internet_search"
description = "Searches the internet for the answer to any question input. Returns a long batch of textual information related to the query."
inputs = {
"question": {
"type": "string",
"description": "The question to retrieve an answer for."
}
}
output_type = "string"
def forward(self, question: str):
print(f"called InternetSearchTool with {question}")
try:
search_tool = DuckDuckGoSearchTool()
result = search_tool(question)
return result
except Exception as e:
return f"ERROR: {e}"
class HubStatsTool(Tool):
name = "hub_stats"
description = "Fetches the most downloaded model from a specific author on the Hugging Face Hub."
inputs = {
"author": {
"type": "string",
"description": "The username of the model author/organization to find models from."
}
}
output_type = "string"
def forward(self, author: str):
try:
# List models from the specified author, sorted by downloads
models = list(list_models(author=author, sort="downloads", direction=-1, limit=1))
if models:
model = models[0]
return f"The most downloaded model by {author} is {model.id} with {model.downloads:,} downloads."
else:
return f"No models found for author {author}."
except Exception as e:
return f"Error fetching models for {author}: {str(e)}"