用Golang做天气查询应用的核心三步是:选OpenWeatherMap等免费API、用net/http发请求并解析JSON、结构化输出;需注意URL编码、坐标查询、结构体tag、状态码与cod字段校验、缓存及错误提示。

用 Golang 做一个天气查询应用不难,核心就三步:选一个稳定免费的天气 API、用 net/http 发请求并解析 JSON、把数据结构化输出(命令行或简单 Web)。下面直接说实用做法,不绕弯。
推荐 OpenWeatherMap(https://www.php.cn/link/a5aef5357bc5d38853c0b0d3cca7bf8c),注册免费账号就能拿到 API Key,每分钟 1000 次调用、每天 1000 次,够个人学习和小工具用。它支持按城市名、坐标、ZIP 码查天气,返回 JSON 清晰,文档友好。
示例请求地址(当前天气):
https://api.openweathermap.org/data/2.5/weather?q=Beijing&appid=YOUR_API_KEY&units=metric
立即学习“go语言免费学习笔记(深入)”;
metric 返回摄氏度,imperial 是华氏度q=%E4%B8%8A%E6%B5%B7,或者直接用英文名 q=Shanghai
/geo/1.0/direct?q={city} 先查坐标,再用 /weather?lat={}&lon={}
不用额外框架,标准库就够了。关键点是定义好结构体,字段名要和 JSON key 对应(注意 tag)。
示例结构体(精简版):
type WeatherResponse struct {
Name string `json:"name"`
Main struct {
Temp float64 `json:"temp"`
FeelsLike float64 `json:"feels_like"`
Humidity int `json:"humidity"`
} `json:"main"`
Weather []struct {
Main string `json:"main"`
Description string `json:"description"`
} `json:"weather"`
}
http.Get() 发请求,记得检查 err 和 resp.StatusCode
json.NewDecoder(resp.Body).Decode(&data) 解析,别用 json.Unmarshal 读全部字节——对大响应不友好{"cod": "404", "message": "city not found"},需手动判断 cod 字段终端里看天气,别堆 JSON。按逻辑分块打印,加点颜色(可选)提升可读性:
time.Now().Format("Jan 2 15:04"))\t 或固定宽度对齐,避免换行错乱进阶可加 flag 支持:weather -city Beijing -unit imperial,用 flag.String 解析参数。
天气变化慢,本地缓存 10 分钟很合理。用 sync.Map 存 map[string]WeatherResponse,key 是 city+unit,value 带时间戳。每次查先判缓存是否过期。
错误处理重点不是“优雅”,而是“有用”:
message 字段基本上就这些。不复杂但容易忽略细节,跑通一次,后面加功能(比如 5 天预报、CLI 自动补全、Web 页面)就顺了。
以上就是如何做一个Golang天气查询应用_Golang第三方API获取与结构化输出的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号