loktar commited on
Commit
075df6b
·
verified ·
1 Parent(s): ae7a494

Added weather tool

Browse files

Testing the adding of a weather tool

Files changed (1) hide show
  1. app.py +17 -5
app.py CHANGED
@@ -1,22 +1,34 @@
1
  from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
  import datetime
3
  import requests
 
4
  import pytz
5
  import yaml
6
  from tools.final_answer import FinalAnswerTool
7
 
8
  from Gradio_UI import GradioUI
9
 
 
 
 
 
 
 
 
 
10
  # Below is an example of a tool that does nothing. Amaze us with your creativity !
11
  @tool
12
- def my_custom_tool(arg1:str, arg2:int)-> str: #it's import to specify the return type
13
  #Keep this format for the description / args / args description but feel free to modify the tool
14
- """A tool that does nothing yet
15
  Args:
16
- arg1: the first argument
17
- arg2: the second argument
18
  """
19
- return "What magic will you build ?"
 
 
 
 
20
 
21
  @tool
22
  def get_current_time_in_timezone(timezone: str) -> str:
 
1
  from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
  import datetime
3
  import requests
4
+ import python_weather
5
  import pytz
6
  import yaml
7
  from tools.final_answer import FinalAnswerTool
8
 
9
  from Gradio_UI import GradioUI
10
 
11
+ async def getweather(city: str) -> int:
12
+ async with python_weather.Client(unit=python_weather.IMPERIAL) as client:
13
+ # fetch a weather forecast from a city
14
+ weather = await client.get(city)
15
+
16
+ return weather.temperature
17
+
18
+
19
  # Below is an example of a tool that does nothing. Amaze us with your creativity !
20
  @tool
21
+ def get_current_temperature_in_city_state(arg1: str)-> str: #it's import to specify the return type
22
  #Keep this format for the description / args / args description but feel free to modify the tool
23
+ """A tool that fetches the current temperature in Fahrenheit in a specified city
24
  Args:
25
+ arg1: A string representing a city
 
26
  """
27
+ try:
28
+ temp = getweather(arg1)
29
+ return f"The current temperature in {arg1} is {temp}f"
30
+ except error:
31
+ return f"Error fetching temperature for the city '{arg1}'"
32
 
33
  @tool
34
  def get_current_time_in_timezone(timezone: str) -> str: