de-vraag
  • 質問
  • タグ
  • ユーザー
通知:
報酬:
登録
登録すると、質問に対する返答やコメントが通知されます。
ログイン
すでにアカウントをお持ちの方は、ログインして新しい通知を確認してください。
追加された質問、回答、コメントには報酬があります。
さらに
ソース
編集
a  barking spider
a barking spider
質問

ネストされたリストからNAsを適切に省略するにはどうすればよいですか?

I'm working with a list of lists - let's call it L - in R, where the sub-lists are all the same length & padded with NAs. Ideally, I'd like to remove just the NA elements from each sublist, and one solution I've come up with is L <- lapply(L, na.omit). It seems to almost work; however, for each sub-list, the behavior is such that, for example,

[[1]]
[1] "0"     "12345"  "12346"  "12347" "12348"  "12349"  "12340"  "12341"  "12342" NA      NA          NA      NA      NA      NA     

[16] NA      NA      NA      NA      NA      NA      NA      NA      NA      NA      NA    

〜になる

[[1]]
[1] "0"     "12345"  "12346"  "12347" "12348"  "12349"  "12340"  "12341"  "12342"
attr(,"na.action")
[1] 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
attr(,"class")
[1] "omit"

私はちょっと思っています。正直なところ、私のリストには余分な attr()などがありますか?それらをリストに追加しないソリューションはありますか?私は na.exclude を試しましたが、同じ結果が得られます。私は行方不明のものがありますか?前もって感謝します : )

4 2011-10-27T19:24:39+00:00 2
プログラミング
r
Joshua Ulrich
27日 10月 2011 в 7:29
2011-10-27T19:29:27+00:00
さらに
ソース
編集
#56791933

想像する理由はありません... ?na.omit の詳細セクションには、

'na.omit'が大文字と小文字を削除すると、大文字と小文字の行番号が   '' na.action ''属性、クラス '"omit"'の結果を返します。

is.na で各リスト要素をサブセット化してみてください:

L <- lapply(L, function(x) x[!is.na(x)])
8
0
Ramnath
27日 10月 2011 в 8:54
2011-10-27T20:54:28+00:00
さらに
ソース
編集
#56791934

高次関数を使用する別のソリューション

lapply(L, Filter, f = Negate(is.na))
3
0
質問の追加
カテゴリ
すべて
技術情報
文化・レクリエーション
生活・芸術
科学
プロフェッショナル
事業内容
ユーザー
すべて
新しい
人気
1
Roxana Elizabeth CASTILLO Avalos
登録済み 6日前
2
Hideo Nakagawa
登録済み 1週間前
3
Sergiy Tytarenko
登録済み 1週間前
4
shoxrux azadov
登録済み 1週間前
5
Koreets Koreytsev
登録済み 1週間前
© de-vraag :年
ソース
stackoverflow.com
ライセンス cc by-sa 3.0 帰属