Data.table: PostgreSQLの%ilike%をdata.tableに含めます

作成日 2017年12月13日  ·  3コメント  ·  ソース: Rdatatable/data.table

SQLクエリに慣れているので、data.tableの%like%演算子がとても気に入っています。 PostgreSQLには、__ i__が大文字と小文字を区別するILIKEオプションもあります-__ insensitive__。

%ilike%をdata.tableに含めることについてどう思いますか?

これをdata.tableに含めるには、like.Rに基づいてilike.Rに演算子%ilike%を作成し、次のようにgrep()呼び出しにignore.case = TRUEを追加します。

ilike <- function(vector, pattern)
{
  # Intended for use with a data.table 'where'
  # Don't use * or % like SQL's like.  Uses regexpr syntax - more powerful.
  if (is.factor(vector)) {
    as.integer(vector) %in% grep(pattern,levels(vector), ignore.case = TRUE)
  } else {
    # most usually character, but integer and numerics will be silently coerced by grepl
    grepl(pattern,vector, ignore.case = TRUE)
  }
  # returns 'logical' so can be combined with other where clauses.
}

"%ilike%" = ilike

再現可能な例:

require(data.table)
cars = data.table(cars = rownames(mtcars), mtcars)

cars[ cars %like% 'fiat' ] # no case-insensitive search possible
cars[ grep('fiat', cars, ignore.case = TRUE) ] # using comparably long grep
cars[ cars %ilike% 'fiat' ] # the new %ilike%
beginner-task

最も参考になるコメント

確かにそれも機能しますが、そのような正規表現を認識していませんでした。 それにもかかわらず、 %ilike%は私にはより直感的に思えます。 PostgreSQLを知っているからかもしれません。 全体として、これはとにかくコーディングスタイルの問題です。

全てのコメント3件

代わりに(?i)タグを使用できます。

cars[cars %like% '(?i)fiat']

確かにそれも機能しますが、そのような正規表現を認識していませんでした。 それにもかかわらず、 %ilike%は私にはより直感的に思えます。 PostgreSQLを知っているからかもしれません。 全体として、これはとにかくコーディングスタイルの問題です。

@andreasLDを上げてくれてありがとう。 そこにもコメントしたのでおそらく見たでしょうが、これは#3333と#3552で閉じられたという記録に注意してください

このページは役に立ちましたか?
0 / 5 - 0 評価