Muntazam ekspression motorlarni taqqoslash - Comparison of regular-expression engines

Bu taqqoslash doimiy ifoda dvigatellar.

Kutubxonalar

Oddiy ekspression kutubxonalar ro'yxati
IsmRasmiy veb-saytDasturlash tiliDastur litsenziyasiTomonidan ishlatilgan
Boost.Regex[Izoh 1]C ++ kutubxonalarini kuchaytirishC ++BoostNotepad ++> = 6.0.0, EmEditor
Boost.XpressiveC ++ kutubxonalarini kuchaytirishC ++Boost 
CL-PPCREEdi VaytsUmumiy LispBSD 
cppreJeff StuartC ++GPL 
DEELXRegExLabC ++Bepul shaxsiy va tijorat maqsadlarida foydalanish 
FREJ[Izoh 2]Java uchun loyqa muntazam iboralarJavaLGPL 
GLib / GRegex[3-eslatma]GLib ma'lumotnomasiCLGPL 
GRETAMicrosoft tadqiqotlariC ++? 
GregexGrovf Inc.RTL, HLSMulkiyFPGA kiberxavfsizlik, moliyaviy, elektron tijorat sohalari uchun> 100Gbit / s regex dvigatelini tezlashtirdi.
RXPTitan ICRTLMulkiyASIC, FPGA va bulut uchun mavjud bo'lgan RegEx-dan foydalangan holda tezlashtirilgan qidiruvni tezlashtirish. Ultra yuqori tezlikda massiv parallel tarkibni qayta ishlashga imkon beradi.
GiperskanIntelC, x86 - maxsus yig'ilish (SSSE3 +[1])3-band BSDRspamd
ICUUnicode uchun xalqaro komponentlarC, C ++[4-eslatma]ICUJamg'arma (Apple va Swift ochiq manbali versiyalari)
Jakarta / RegexpApache Jakarta loyihasiJavaApache 
java.util.regexJava foydalanuvchi qo'llanmasiJavaClasspath istisnosiz GNU GPLv2jEdit
JRegexJRegexJavaBSD 
MATLABMuntazam iboralarMATLAB tiliMATLAB, Texnik hisoblash tili 
OnigurumaKosakoCBSDAtom, Buyruqning konsolini oling, Tera muddati, TextMate, Yuqori matn, SubEthaEdit, EmEditor va jq
Onigmo (Oniguruma-mod)OnigmoCBSDYoqut
PattvoStivsoftJava (Java 1.0 bilan mos)LGPL 
PCREpcre.orgC, C ++[5-eslatma]BSDApache HTTP Server, Nginx, BBEdit, Yuliya, HHVM, Notepad ++ <6.0.0, PHP, Delphi, R
Qt / QRegExpDigiaC ++Qt GNU GPL v. 3.0,

Qt GNU LGPL v. 2.1,Qt tijorat

Kate, Kile
regex - Genri Spenser muntazam ekspression kutubxonalariArgListCBSD 
RE2RE2C ++BSDBoring, Google Sheets, Gmail, G Suite
Genri Spenser Kengaytirilgan muntazam iboralarTclCBSD 
RGXRGX C ++ asosidagi komponentalar kutubxonasiP6R 
SubRegMett BaknollCMIT 
TPerlRegExTPerlRegEx VCL komponentiOb'ekt PaskalMPLv1.1 
TRE[Izoh 2]Ville LaurikariCBSDmusulmon
TRegExprRegExp StudioOb'ekt PaskalIkki litsenziya: bepul dastur yoki statik ulanish istisnosiz LGPLJami qo'mondon
XRegExpXRegExpJavaScriptMIT 
Wolfram tili (Matematik )Wolfram tilini hujjatlashtirish markaziWolfram tiliMatematik, Wolfram ishlab chiqish platformasi
  1. ^ Ilgari Regex ++ deb nomlangan.
  2. ^ a b Bittasi loyqa-odatiy ifoda dvigatellar.
  3. ^ 2.13.0 versiyasidan beri kiritilgan.
  4. ^ ICU4J, Java versiyasi, oddiy iboralarni qo'llab-quvvatlamaydi.
  5. ^ C ++ ulanishlari Google tomonidan ishlab chiqilgan va 2006 yilda rasmiy ravishda PCRE tarkibiga kirgan.

Tillar

Oddiy ekspresni qo'llab-quvvatlashni o'z ichiga olgan tillar va ramkalar ro'yxati
TilRasmiy veb-saytDastur litsenziyasiIzohlar
ActionScript 3ActionScript texnologiyalari markaziOzod
APL (APLX, Dyalog, GNU)APL WikiTegishli dastur tomonidan litsenziyalanganSSS (PCRE), .R/.S (PCRE), SSS (PCRE2) navbati bilan
C ++ 11 (C ++ )C ++ standartlari veb-saytiTegishli dastur tomonidan litsenziyalanganISO14822: 2011 (e) dan boshlab, sukut bo'yicha ECMAScript-ga o'xshash (Grammatik tavsif)
D.D.Dastur litsenziyasini oshirish[Izoh 1]
BoringGolang.orgBSD uslubi
XaskellHaskell.orgBSD3Til hisobotida va GHC Ierarxik kutubxonalarida chiqarib tashlangan
JavaJavaGNU umumiy jamoat litsenziyasiRE-lar manba kodida satrlar sifatida yoziladi: barcha teskari burilishlar ikki baravarga ko'paytirilishi kerak, bu esa o'qishga zarar etkazadi.
JavaScript (ECMAScript )ECMA-262BSD3Cheklangan, ammo RE - bu o'ziga xos xususiyatga ega bo'lgan birinchi darajali fuqarolar /.../mod sintaksis.
YuliyaJuliaLang.orgMIT litsenziyasiRE-lar tilning asosiy kutubxonasining bir qismi bo'lib, o'rnatilgan PCRE-dan foydalaniladi va (C kodi) ICU uchun ixtiyoriy o'ram mavjud.
LuaLua.orgMIT litsenziyasiSoddalashtirilgan, cheklangan shevadan foydalanadi; PCRE yoki LPeg singari muqobil ajraluvchi kabi yanada kuchli kutubxonaga bog'lanishi mumkin.
MatematikWolframMulkiy
.NETMSDNMIT litsenziyasi[Izoh 2][3-eslatma]
Nimnim-lang.orgMIT litsenziyasiStandart kutubxona PCRE-ga asoslangan qayta va nre modullar, shuningdek turli xil alternativalar (masalan, stullar, qoziqlar (Ifoda grammatikasini tahlil qilish taalukli), strkanlar, parseutils, va boshqalar.).
Bepul Paskal (Ob'ekt Paskal )www.freepascal.orgLGPL statik bog'lovchi istisno bilanSorokindan va yana ikkita doimiy ekspresiya kutubxonasidan TRegExpr bilan bepul Paskal 2.6+ kemalari; Qarang wiki.lazarus.freepascal.org/Regexpr.
OCamlKemaLGPL2010 yildan boshlab, standart modul odatda eskirgan deb hisoblanadi;[2] ko'pincha tavsiya etilgan kutubxonalar pcre (PCRE uchun to'liq qo'llab-quvvatlash bilan) va qayta (bu unchalik to'liq emas, lekin yaxshi ishlashni talab qiladi va ommabop sintaksislarning old tomonlarini ta'minlaydi: PCRE, Perl, Posix, Emacs, qobiq globbingi).
PerlPerl.comBadiiy litsenziya, yoki GNU umumiy jamoat litsenziyasiTilning to'liq, markaziy qismi
PHPPHP.netPHP litsenziyasiPCRE tezligi va funktsiyalari bo'yicha samaraliroq bo'lgan ikkita dasturga ega
POSIX C (C )POSIX.1 veb-nashriTegishli dastur tomonidan litsenziyalanganQo'llab-quvvatlaydi POSIX BRE va ERE sintaksis
Pythonpython.orgPython Software Foundation litsenziyasiPython-da o'rnatilgan ikkita asosiy dastur mavjud qayta va regex kutubxona.
Yoqutruby-doc.orgGNU kutubxonasi umumiy ommaviy litsenziyasiRuby 1.8, Ruby 1.9 va Ruby 2.0 va undan keyingi versiyalarida turli xil dvigatellardan foydalaniladi; Ruby 1.9 Oniguruma-ni, Ruby 2.0-ni va keyinchalik Oniguruma-ning vilkasini Onigmo-ni birlashtiradi.
Zangdocs.rsMIT litsenziyasiBirlamchi regex sandig'i atrofni ifodalashga imkon bermaydi. Oniguruma majburiy deb nomlangan onig shunday qiladi.
SAP ABAPSAP.comMulkiy
Tcltcl.tkTcl / Tk litsenziyasi
(BSD uslubi)
Tcl kutubxonasi odatiy ekspressiya kutubxonasi vazifasini bajaradi.
Wolfram tiliWolfram tadqiqotlariMulkiy: Wolfram Development platformasida cheklangan miqyosda bepul foydalanish
XML sxemasiW3CTegishli dastur tomonidan litsenziyalangan
XPath 3 /XQueryW3CTegishli dastur tomonidan litsenziyalangan

Til xususiyatlari

ESLATMA: Muntazam ekspression qo'llab-quvvatlash uchun kutubxonadan foydalanadigan dastur kutubxonaning barcha funktsiyalarini taklif qilishi shart emas, masalan. PCRE-ni ishlatadigan GNU grep, tashqi ko'rinishini qo'llab-quvvatlamaydi, ammo PCRE-da.

1 qism

Til xususiyatlarini taqqoslash (1 qism)
"+" miqdoriy ko'rsatkichiSalbiy belgilar sinflariOchko'z bo'lmagan miqdoriy ko'rsatkichlar
[Izoh 1]
Uyatchan guruhlar
[Izoh 2]
RekursiyaOldinga qarashOrqaga qarashOrqaga havolalar
[3-eslatma]
> 9 indeksatsiya qilinadigan suratga olish
Boost.RegexHaHaHaHaHa[4-eslatma]HaHaHaHa
Boost.XpressiveHaHaHaHaHa[5-eslatma]HaHaHaHa
CL-PPCREHaHaHaHaYo'qHaHaHaHa
EmEditorHaHaHaHaYo'qHaHaHaYo'q
FREJYo'q[6-eslatma]Yo'qBiroz[6-eslatma]HaYo'qYo'qYo'qHaHa
GLib / GRegexHaHaHaHaHaHaHaHaHa
GNU grepHaHaHaHaYo'qHaHaHa?
XaskellHaHaHaHaYo'qHaHaHaHa
RXPHaHaHaHaYo'qYo'qYo'qHaHa
ICU RegexHaHaHaHaYo'qHaHaHaHa
JavaHaHaHaHaYo'qHaHaHaHa
JavaScript (ECMAScript )HaHaHaHaYo'qHaHa[7-eslatma]HaHa
JGsoftHaHaHaHaYo'qHaHaHaHa
LuaHaHaBiroz[8-eslatma]Yo'qYo'qYo'qYo'qHaYo'q
.NETHaHaHaHaYo'qHaHaHaHa
OCamlHaHaYo'qYo'qYo'qYo'qYo'qHaYo'q
PCREHaHaHaHaHaHaHaHaHa
PerlHaHaHaHaHaHaHaHaHa
PHPHaHaHaHaHaHaHaHaHa
PythonHaHaHaHaHa[9-eslatma]HaHaHaHa
Qt / QRegExpHaHaHaHaYo'qHaYo'qHaHa
RE2HaHaHaHaYo'qYo'qYo'qYo'qHa
Ruby / OnigmoHaHaHaHaHaHaHaHaHa
TREHaHaHaHaYo'qYo'qYo'qHaYo'q
VimHaHaHaHaYo'qHaHaHaYo'q
RGXHaHaHaHaYo'qHaHaHaHa
TclHaHaHaHaYo'qHaHaHaHa
TRegExprHa?Ha??????
XML sxemasiHaHaYo'qYo'qYo'qYo'qYo'qYo'qYo'q
XPath 3 /XQueryHaHaHaHaYo'qYo'qYo'qHaHa
XRegExpHaHaHaHaYo'qHaYo'qHaHa
  1. ^ Ochko'z emas sukut bo'yicha emas, balki miqdoriy belgilar imkon qadar kamroq belgilarga mos keladi. E'tibor bering, ko'plab yoshi kattaPOSIX dvigatellar ochko'zlik qilmagan va ochko'zlik ko'rsatkichlari umuman bo'lmagan.
  2. ^ Uyatchan guruhlardeb nomlangan ushlamaslik guruhlarga qayta havolalar bilan murojaat qilish mumkin emas; ta'qib qilmaydigan guruhlar moslashtirishni tezlashtirish uchun ishlatiladi, bu erda guruh tarkibiga keyinroq kirish kerak bo'lmaydi.
  3. ^ Orqaga havolalar regex va / yoki almashtirish satrining keyingi qismlarida ilgari mos keladigan guruhlarga murojaat qilishni yoqing (agar kerak bo'lsa). Masalan; misol uchun, ([ab] +) 1 "abab" bilan mos keladi, ammo "abaab" ga to'g'ri kelmaydi.
  4. ^ http://www.boost.org/doc/libs/1_47_0/libs/regex/doc/html/boost_regex/syntax/perl_syntax.html#boost_regex.syntax.perl_syntax.recursive_expressions
  5. ^ http://www.boost.org/doc/libs/1_47_0/doc/html/xpressive/user_s_guide.html#boost_xpressive.user_s_guide.grammars_and_nested_matches.embedding_a_regex_by_reference
  6. ^ a b FREJda takrorlanadigan miqdoriy ko'rsatkichlar mavjud emas, ammo oddiy "?" Ga o'xshash "ixtiyoriy" element mavjud. miqdoriy.
  7. ^ ES2018 yildan boshlab
  8. ^ Luaning ochko'z bo'lmagan yagona miqdori -, bu ochko'z bo'lmagan versiya *. Unda ochko'z bo'lmagan versiyalar mavjud emas + yoki ?; avvalgi holatda, ochko'z bo'lmagan ta'sirga belgini takrorlash orqali erishish mumkin -, ammo ikkinchi holatda, unga teng keladigan narsa yo'q.
  9. ^ Ixtiyoriy tomonidan qo'llab-quvvatlanadi regex faqat kutubxona.

2-qism

Til xususiyatlarini taqqoslash (2 qism)
Direktivalar
[Izoh 1]
ShartliAtom guruhlari
[Izoh 2]
Qo'lga olish deb nomlangan
[3-eslatma]
IzohlarIchki kodUnicode mulkni qo'llab-quvvatlash [3]Muvozanat guruhlari
[4-eslatma]
O'zgaruvchan uzunlikdagi qarashlar
[5-eslatma]
Boost.RegexHaHaHaHaHaYo'qBiroz[6-eslatma]Yo'qYo'q
Boost.XpressiveHaYo'qHaHaHaYo'qYo'qYo'qYo'q
CL-PPCREHaHaHaHaHaHaBiroz[6-eslatma]Yo'qYo'q
EmEditorHaHa??HaYo'q?Yo'qYo'q
FREJYo'qYo'qHaHaHaYo'q?Yo'qYo'q
GLib / GRegexHaHaHaHaHaYo'qBiroz[6-eslatma]Yo'qYo'q
GNU grepHaHa?HaHaYo'qYo'qYo'qYo'q
Xaskell?????Yo'qYo'qYo'qYo'q
RXPHaHaYo'qHaHaYo'qYo'qYo'qYo'q
ICU RegexHaYo'qHaHa[7-eslatma]HaYo'qHaYo'qYo'q
JavaHaYo'qHaHa[8-eslatma]HaYo'qBiroz[6-eslatma]Yo'qYo'q
JavaScript (ECMAScript )Yo'qYo'qYo'qYo'qYo'qYo'qBiroz[6-eslatma][9-eslatma][4]Yo'qYo'q
JGsoftHaHaHaHaHaYo'qBiroz[6-eslatma]Yo'qHa
LuaYo'qYo'qYo'qYo'qYo'qYo'qYo'qYo'qYo'q
.NETHaHaHaHaHaYo'qBiroz[6-eslatma]HaHa
OCamlYo'qYo'qYo'qYo'qYo'qYo'qYo'qYo'qYo'q
PCREHaHaHaHaHaHaHaYo'qYo'q
PerlHaHaHaHaHaHaHaYo'qYo'q[10-eslatma]
PHPHaHaHaHaHaYo'qYo'qYo'qYo'q
PythonHaHaHa[11-eslatma]HaHaYo'qHa[12-eslatma]Yo'qHa[11-eslatma]
Qt / QRegExpYo'qYo'qYo'qYo'qYo'qYo'qYo'qYo'qYo'q
RE2HaYo'q?HaYo'qYo'qBiroz[6-eslatma]Yo'qYo'q
Ruby / OnigmoHaHaHaHaHaHaBiroz[6-eslatma]Yo'qYo'q
TclHaYo'qHaYo'qHaYo'qHaYo'qYo'q
TREHaYo'qYo'qYo'qHaYo'q?Yo'qYo'q
VimHaYo'qHaYo'qYo'qYo'qYo'qYo'qHa
RGXHaHaHaHaHaYo'qHaYo'qYo'q
XML sxemasiYo'qYo'qYo'qYo'qYo'qYo'qHaYo'qYo'q
XPath 3 /XQueryYo'qYo'qYo'qYo'qYo'qYo'qHaYo'qYo'q
XRegExpFaqat etakchiYo'qYo'qHaHaYo'qHaYo'qYo'q
  1. ^ Shuningdek, nomi bilan tanilgan bayroqlar modifikatorlari, rejimlarni o'zgartiruvchilar yoki variant harflari. Namunaviy naqsh: "(? I: test)".
  2. ^ Shuningdek, chaqirildi mustaqil kichik iboralar.
  3. ^ Orqa havolalarga o'xshash, ammo indekslar o'rniga ismlar.
  4. ^ Balansli konstruktsiyalarni rekursiyasiz moslashtirishga imkon beruvchi maxsus xususiyat.
  5. ^ Miqdorlarni orqaga qarashga kiritish imkoniyatini nazarda tutadi, shuning uchun ularning uzunligini oldindan aytib bo'lmaydi.
  6. ^ a b v d e f g h men Unicode-ni qo'llab-quvvatlash to'liq bo'lmasligi mumkin (mahsulotlar doimiy ravishda yangilanadi!). Hammasi to'liq bo'lmaydi yangi Unicode versiyasi chiqarilganda qadar ular mos ravishda yangilanadi.
  7. ^ ICU55 dan foydalanish mumkin.
  8. ^ JDK7 dan foydalanish mumkin.
  9. ^ Qo'llab-quvvatlash va xususiyatlar doirasi amalga oshirishga bog'liq.
  10. ^ V5.29.9 da qo'shilgan eksperimental yordam.
  11. ^ a b Ixtiyoriy tomonidan qo'llab-quvvatlanadi regex faqat kutubxona.
  12. ^ 3.3 dan keyin Python versiyalari bilan foydalanilganda faqat regex kutubxonasida mavjud bo'lishi mumkin.

API xususiyatlari

API xususiyatlarini taqqoslash
Mahalliy UTF-16 qo'llab-quvvatlash[Izoh 1]Mahalliy UTF-8 qo'llab-quvvatlash[Izoh 1]Ko'p qatorli moslikQisman o'yin[Izoh 2]
Boost.RegexYo'qYo'qHaHa
GLib / GRegexHaHaHaHa
RXPHaHaYo'qHa
ICU RegexHaYo'qHa?
JavaYo'qQisman[3-eslatma]HaHa
.NETYo'q[4-eslatma]HaHa?
PCREHa[5-eslatma]HaHaHa
Qt / QRegExpHaYo'qYo'q?
TclHaHa[6-eslatma]Ha?
TREHaHaHa?
RGXYo'qYo'qHa?
wxWdigets::wxRegEx[7-eslatma]HaHaHa?
XRegExpHa?Ha?
  1. ^ a b Ushbu format aniq konversiyasiz ichki ishlatilishi mumkin degan ma'noni anglatadi.
  2. ^ Butun doimiy ifodaning qisman mosligi. Masalan, ". * END $" naqshlari har qanday satrga qisman mos keladi, lekin faqat END bilan tugaydigan satrlar to'liq.[1].
  3. ^ 2003 yildan boshlab Unicode 4.0 standartini qo'llab-quvvatlaydi; JDK7 uchun so'nggi rejalarga Unicode 6.0 (2011) ko'magi kiradi.[2].
  4. ^ Amalga oshirish originaldan foydalanadi UCS-2 qo'llab-quvvatlash / xususiyatlar, shuning uchun u faqat 64K belgilarni taniydi (va boshqalar) UTF-16 1.112.064 belgidan iborat). Microsoft ishlab chiqaruvchisi vakili bu haqda xatolar haqidagi xabarga 2010 yilda "tuzatmaydi" deb javob berdi.[3].
  5. ^ 8.30 versiyasidan beri.
  6. ^ Tcl tarkibiga UTF-8 ga o'tish va qaytish uchun moslamalar kiradi.
  7. ^ wxRegEx ta'minlangan har qanday tizimdan foydalanadi POSIX kutubxonasi yoki mavjud bo'lmasa va Unicode rejimi foydalanadi Genri Spenser kutubxona.

Shuningdek qarang

Adabiyotlar

  1. ^ https://intel.github.io/hyperscan/dev-reference/getting_started.html#requirements
  2. ^ [4]
  3. ^ https://www.unicode.org/reports/tr18/
  4. ^ "ECMA-262, 9-nashr, 2018 yil iyun ECMAScript® 2018 tilining spetsifikatsiyasi". www.ecma-international.org. Olingan 4 avgust 2020.

Tashqi havolalar