Data.table: Fügen Sie %ilike% von PostgreSQL in data.table ein

Erstellt am 13. Dez. 2017  ·  3Kommentare  ·  Quelle: Rdatatable/data.table

Ich mag den Operator %like% in data.table sehr, da ich an SQL-Abfragen gewöhnt bin. In PostgreSQL gibt es auch die ILIKE- Option, wobei das __i__ für case-__insensitive__ steht.

Was halten Sie davon, %ilike% in data.table aufzunehmen?

Um dies in data.table einzufügen, würde ich einen Operator %ilike% in ilike.R basierend auf like.R erstellen und ignore.case = TRUE wie folgt zu den grep() -Aufrufen hinzufügen:

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

reproduzierbares Beispiel:

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

Hilfreichster Kommentar

Stimmt, das funktioniert auch, war mir einer solchen Regex nicht bewusst. Trotzdem erscheint mir %ilike% intuitiver. Vielleicht, weil ich PostgreSQL kenne. Insgesamt ist das sowieso eine Frage des Programmierstils.

Alle 3 Kommentare

Sie könnten stattdessen das Tag (?i) verwenden:

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

Stimmt, das funktioniert auch, war mir einer solchen Regex nicht bewusst. Trotzdem erscheint mir %ilike% intuitiver. Vielleicht, weil ich PostgreSQL kenne. Insgesamt ist das sowieso eine Frage des Programmierstils.

@andreasLD Nochmals vielen Dank für die Erhöhung. Sie haben wahrscheinlich gesehen, da Sie dort auch kommentiert haben, aber fürs Protokoll bemerkt haben, dass dies in # 3333 und # 3552 geschlossen wurde

War diese Seite hilfreich?
0 / 5 - 0 Bewertungen