質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

2187閲覧

jismeshにExcelから読み込んだメッシュコード(749個)をfor文等を使って上から順に代入し表示したい

YuLin

総合スコア2

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/01/06 06:48

編集2022/01/06 09:57

前提・実現したいこと

pythonを始めたばかりで調べてもわからず困っています。

jismeshをつかって地域メッシュコードから中心点の座標を表示させる。
Excelにまとめた、とある市の3次メッシュコード(749個)をpythonに読み込ませた。そのメッシュコードをfor文を使って上から順に代入して一気に全部表示させたい。

発生している問題・エラーメッセージ

IndexError: too many indices for array: array is 1-dimensional, but 3 were indexed

該当のソースコード

python

1import jismesh.utils as ju 2import pandas as pd 3 4df = pd.read_excel("C:/Users/user/Desktop/excel/Key.xlsx",skiprows=1,usecols="A") 5 6keycode = [df] 7 8for point in keycode: 9 lat_c, lon_c = ju.to_meshpoint(keycode, 0.5, 0.5) 10 11 12 13 14[追記] 15import jismesh.utils as ju 16import pandas as pd 17 18df = pd.read_excel("C:/Users/user/Desktop/excel/Key.xlsx") 19 20print(df) 21 22df['lat'], df['lon'] = ju.to_meshpoint(df, lat_multiplier=0.5, lon_multiplier=0.5) 23 24print(df) 25 26[実行結果] 27 28 52350149 290 52350149 301 52350159 312 52350159 323 52350169 334 52350169 34.. ... 35743 52351020 36744 52351021 37745 52351023 38746 52351024 39747 52351030 40 41[748 rows x 1 columns] 42Traceback (most recent call last): 43 File "c:\Users\user\Desktop\Python\3mesh.py", line 8, in 44<module> 45 df['lat'], df['lon'] = ju.to_meshpoint(df, lat_multiplier=0.5, 46lon_multiplier=0.5) 47 File "C:\Users\user\AppData\Local\Programs\Python\Python310\lib\site-packages\jismesh\utils\__init__.py", line 46, in to_meshpoint return to_meshpoint(meshcode, lat_multiplier, lon_multiplier) 48 File "C:\Users\user\AppData\Local\Programs\Python\Python310\lib\site-packages\jismesh\utils\_vector.py", line 493, in to_meshpoint lat += unit_lat(level)*lat_multiplier 49 File "C:\Users\user\AppData\Local\Programs\Python\Python310\lib\site-packages\jismesh\utils\_vector.py", line 57, in unit_lat 50 lat[level==1] = _unit_lat_lv1() 51IndexError: too many indices for array: array is 1-dimensional, but 2 were indexed 52

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

jismeshの使用例のコードのとおりにすればよいです。

Python

1import jismesh.utils as ju 2import pandas as pd 3 4#df = pd.read_excel("C:/Users/user/Desktop/excel/Key.xlsx",skiprows=1,usecols="A") 5df = pd.DataFrame({'A':[53393599, 52353680]}) 6 7# pandas DataFrame中のメッシュコードを中心点緯度経度に変換する。 8df['lat_c'], df['lon_c'] = ju.to_meshpoint(df.A, lat_multiplier=0.5, lon_multiplier=0.5) 9print(df) 10# A lat_c lon_c 11#0 53393599 35.6625 139.74375 12#1 52353680 34.9875 135.75625

投稿2022/01/06 07:21

can110

総合スコア38341

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

YuLin

2022/01/06 08:42

解答ありがとうございます。読み込んだExcelを4行目の数値の部分に入れて実行する、ということでしょうか?いろいろ試したのですがエラーを吐いてしまっていて、、、
can110

2022/01/06 09:15

回答コードでコメントアウトしている部分のほうを生かせばよいです。 データ形式が正しければ問題なく動作すると思います。
YuLin

2022/01/06 09:43

IndexError: too many indices for array: array is 1-dimensional, but 2 were indexedというエラーがでてしまいます。どこで2つのインデックスを渡しているのかがわかりません。
can110

2022/01/06 09:49

どのようなコードの中のどの部分でエラーが出たかがよくわからないので 現象が再現するコード全文とエラー全文を質問に追記ください。 また、print(df)なりして、データ内容も提示ください。
YuLin

2022/01/06 09:58

該当のソースコードの欄に追加しました。お手数をおかけして大変申し訳ございませんが何卒よろしくお願いします。
can110

2022/01/06 10:45

「ju.to_meshpoint(df, ~」のところですね。 df全体を渡しているのでエラーになっています。 「ju.to_meshpoint(df.A, ~」と列を指定してください。
YuLin

2022/01/06 11:07

解決しました!本当に最後までご丁寧にありがとうございました。非常に助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問