【问题标题】:hourly weather forecast using openweathermap api使用 openweathermap api 的每小时天气预报
【发布时间】:2017-03-24 19:28:29
【问题描述】:

我正在尝试使用改造库使用此 url http://api.openweathermap.org/data/2.5/forecast?q=London&APPID 从 openweathermap api 获取每小时预报数据,但此 url 不起作用..

API接口类

public interface ApiInterface {
@GET("forecast?")
Call<HourlyWeather> getHourlyWeather(@Query("q") String city,
                                     @Query("units") String units,
                                     @Query("APPID") String appId);

}

api 客户端类

public class ApiClient {
public static final String BASE_URL="http://api.openweathermap.org/data/2.5/";
public static Retrofit retrofit =null;

public static Retrofit getRetrofit(){
    if (retrofit == null){

        retrofit = new Retrofit.Builder()
                .baseUrl(BASE_URL)
                .addConverterFactory(GsonConverterFactory.create())
                .build();
    }
    return retrofit;

}

}

改造响应

ApiInterface apiInterface = ApiClient.getRetrofit().create(ApiInterface.class);
    Call<HourlyWeather> call = apiInterface.getHourlyWeather("London","metric",getResources().getString(R.string.api_key));
    call.enqueue(new Callback<HourlyWeather>() {
        @Override
        public void onResponse(Call<HourlyWeather> call, Response<HourlyWeather> response) {
            Log.d("Hourly","Status code "+response.code());
             list = response.body().getList();

           hourlyTxt.setText(getString(R.string.hourly_forecast));
        }

        @Override
        public void onFailure(Call<HourlyWeather> call, Throwable t) {
                t.printStackTrace();
        }
    });
}

Logcat 错误:

com.google.gson.JsonSyntaxException: java.lang.NumberFormatException: Expected an int but was 1035.16 at line 1 column 138 path $.list[0].main.pressure
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.TypeAdapters$7.read(TypeAdapters.java:245)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.TypeAdapters$7.read(TypeAdapters.java:235)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:129)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:220)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:129)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:220)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.read(TypeAdapterRuntimeTypeWrapper.java:41)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.CollectionTypeAdapterFactory$Adapter.read(CollectionTypeAdapterFactory.java:82)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.CollectionTypeAdapterFactory$Adapter.read(CollectionTypeAdapterFactory.java:61)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:129)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:220)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at retrofit2.converter.gson.GsonResponseBodyConverter.convert(GsonResponseBodyConverter.java:37)
03-25 18:41:17.789 16913-16913/com.example.prem.weatherapp W/System.err:     at retrofit2.converter.gson.GsonResponseBodyConverter.convert(GsonResponseBodyConverter.java:25)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at retrofit2.ServiceMethod.toResponse(ServiceMethod.java:118)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at retrofit2.OkHttpCall.parseResponse(OkHttpCall.java:212)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at retrofit2.OkHttpCall$1.onResponse(OkHttpCall.java:106)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at okhttp3.RealCall$AsyncCall.execute(RealCall.java:135)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at java.lang.Thread.run(Thread.java:818)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err: Caused by: java.lang.NumberFormatException: Expected an int but was 1035.16 at line 1 column 138 path $.list[0].main.pressure
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.stream.JsonReader.nextInt(JsonReader.java:1196)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:     at com.google.gson.internal.bind.TypeAdapters$7.read(TypeAdapters.java:243)
03-25 18:41:17.790 16913-16913/com.example.prem.weatherapp W/System.err:    ... 20 more

提前谢谢...

【问题讨论】:

  • 什么不起作用?
  • 每小时数据不显示,logcat中也有响应代码
  • 请显示日志输出
  • 没有响应码@NinoHandler的数据
  • 状态码 200 未在此特定网址中显示我

标签: android android-studio retrofit


【解决方案1】:

您期待一个 int,但 main.pressure 收到了一个 double。

NumberFormatException: Expected an int but was 1035.16

【讨论】:

    猜你喜欢
    • 2021-07-28
    • 2020-05-12
    • 1970-01-01
    • 1970-01-01
    • 2021-05-01
    • 1970-01-01
    • 2020-05-13
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多