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

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

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

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

1回答

4531閲覧

データフレームの各行に関数を適用したい

trial

総合スコア13

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

1クリップ

投稿2017/12/18 14:23

編集2017/12/18 14:55

いつもお世話になります。
データフレームの操作方法について皆様のお知恵を拝借いただけないでしょうか。

##前提・実現したいこと
目標としては、データフレーム上のデータを関数で演算し、元のデータフレームに追加したいです。

今回の例で話をするとデータフレーム内にあるlat,lonという列データをmeshcode関数(自作関数)に渡して、meshcodeという列を元のデータフレームに追加するのが目標です。

lat lon 34.94975752 139.0699043 34.94975753 139.0699043 34.94975754 139.0699043 34.9497575 139.0699043

データ加工例。(ゴール)

lat lon meshcode 34.94975752 139.0699043 52393035 34.94975753 139.0699043 52393035 34.94975754 139.0699043 52393035 34.9497575 139.0699043 52393035

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

エラーメッセージ TypeError: cannot convert the series to <class 'float'>

##該当のソースコード
mainファイル

#メッシュコード変換関数の格納フォルダを指定↓ import sys; sys.path.append(r'module_folder_path') #メッシュコード変換関数↓ import latlong_to_meshcode as msh import pandas as pd import numpy as np import datetime data = pd.read_table('filedata',names=['lat','lon'],header=0,dtype = 'object') var_id = ['id'] var_val = ['lat','lon'] data[var_id] = data[var_id].astype(object) data[var_val] = data[var_val].astype(float) df['meshcode']=msh.latlong_to_meshcode(df['lat'],df['lon']))

メッシュコード変換ファイル

def latlong_to_meshcode(lat, long, order = 3): if type(lat) != float: # 実数型でないなら変換 lat = float(lat) if type(long) != float: # 実数型でないなら変換 long = float(long) if (order < 1) | (order > 3): raise Exception ("Invalid parameter to latlong_to_meshcode()") # Latitude lat_in_min = lat * 60.0 code12 = int(lat_in_min / 40) # codeの1, 2文字目部分(数値) lat_rest_in_min = lat_in_min - code12 * 40 # 残差 code5 = int(lat_rest_in_min / 5 ) # code 5文字目 二次メッシュの1区画は緯度5分 lat_rest_in_min -= code5 * 5 # 残差 code7 = int(lat_rest_in_min / (5/10)) # code 7文字目 三次メッシュの1区画は緯度5分の 1/10 # Longitude code34 = int(long) - 100 # codeの3, 4文字目部分(数値) long_rest_in_deg = long - int(long) code6 = int(long_rest_in_deg * 8) long_rest_in_deg -= code6 / 8; code8 = int(long_rest_in_deg / (1/80) ) code = code12 * 100 + code34 if order >= 2: code = code * 100 + code5 * 10 + code6 if order == 3: code = code * 100 + code7 * 10 + code8 return int(code)

##実施した内容
df.apply(axis=1)でlat/lonの列にmeshcodeの関数を渡してみたのですが、keyerrorを出力してしまいました。

data['lat','lon'].apply(msh.latlong_to_meshcode,axis=1)

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

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

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

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

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

guest

回答1

0

ベストアンサー

.applyのパターンで、
gps[['lat','lon']].apply(.....)

python

1def latlong_to_meshcode(lat_and_long, order=3): 2 lat = lat_and_long[0] 3 lon = lat_and_long[1] 4 ....

としてもKeyErrorが出ますか?

投稿2017/12/18 14:48

mkgrei

総合スコア8560

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

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

trial

2017/12/18 15:10

回答有難うございます! ご助言いただきました通り、meshcode関数を修正し、渡す変数を1つにしたら無事動作しました! 助かりました。m(_ _)m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問