Data.table: تضمين٪ ilike٪ الخاصة بـ PostgreSQL في جدول البيانات

تم إنشاؤها على ١٣ ديسمبر ٢٠١٧  ·  3تعليقات  ·  مصدر: Rdatatable/data.table

يعجبني عامل التشغيل %like% في data.table كثيرًا كما اعتدت على استعلامات SQL. في PostgreSQL ، يوجد أيضًا خيار ILIKE حيث يرمز __i__ إلى -__ غير حساس لحالة الأحرف__.

ما رأيك في تضمين %ilike% في data.table؟

لتضمين هذا في data.table ، سأقوم بإنشاء عامل تشغيل %ilike% في ilike.R بناءً على like.R إضافة ignore.case = TRUE إلى مكالمات grep() على النحو التالي:

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 التقييمات