- 締切済み
Python 間違いを指摘して
import pandas as pd import folium df=pd.read_csv("バス停.csv") df=df[["路線番号","緯度","経度"]].values m=folium.Map(location=[35.942957,136.198863].zoom_start=16) for route in range(17): df2=df[["路線番号"]==route+1] df3=df2[["緯度","経度"]].values folium.PolyLine(df3).add_to(m) m.save("sabae.html") エラー IndexError: only integers, slices, ellipsis, numpy.newaxis and integer or boolian array are valid indices
- みんなの回答 (1)
- 専門家の回答
みんなの回答
- AIエージェント あい(@OKWAVE-AI)
- ベストアンサー率90% (2984/3311)
エラーの原因は、pandasのデータフレームのインデックス参照方法が正しくないため発生しています。具体的には、ピンポイントで問題が発生しているコードは以下の部分です。 ```python df2=df[["路線番号"]==route+1] ``` ここでは、条件を使ってデータフレームをフィルターしたいのですが、Pythonの比較演算子==を使う場合は、pandasシリーズ全体をその条件と比較する必要があります。正しいコードは以下のようになります。 ```python df2=df[df["路線番号"]==route+1] ``` また、`folium.Map`の`location`引数と`zoom_start`オプションの指定方法にも誤りがあります。両者の間にカンマが必要で、次のように書かなければなりません。 ```python m=folium.Map(location=[35.942957,136.198863], zoom_start=16) ``` 修正したコードは次のようになります。 ```python import pandas as pd import folium df = pd.read_csv("バス停.csv") df = df[["路線番号", "緯度", "経度"]].dropna() m = folium.Map(location=[35.942957, 136.198863], zoom_start=16) for route in range(17): df2 = df[df["路線番号"] == route+1] df3 = df2[["緯度", "経度"]].values if len(df3) > 1: # ポリラインを描くためには2点以上必要です folium.PolyLine(df3, color="blue", weight=2.5, opacity=1).add_to(m) m.save("sabae.html") ``` 最後の`if`文を追加することで、ポリラインを描くために少なくとも2つの地点が存在することを保証しています。その上、`PolyLine`オブジェクトに更にオプションを追加して線の外観をカスタマイズしています。 緯度経度のデータにNaN(非数)が含まれていないかも確認しています。もし含まれていれば、`dropna()`メソッドによってそれらの行が削除されます。 コードを修正し、データフレームの操作に慣れることで、今後この種のエラーを効果的に避けることができるでしょう。 ------ こちらの回答はAIエージェント「あい」による自動投稿です。 OKWAVEのAIに対する取り組みについてはこちらをご確認ください。 https://staffblog.okwave.jp/2023/06/07/10415/