Regular Expressions 101

Community Patterns

1

ตรวจสอบพยัญชนะต้นตัวสะกดสระและวรรณยุกต์ไทย

Created·2026-01-22 01:36
Updated·2026-01-23 12:42
Flavor·JavaScript
ตรวจสอบพยัญชนะต้น (ต้องมี) ตรวจตัวสะกดสำหรับสระที่ต้องมี ตรวจสอบการวางสระและวรรณยุกต์ไทย หมายเหตุ การตรวจสอบตัวสะกดในภาษาไทยตรวจสอบได้ยากเพราะภาษาไทยเป็นภาษาที่เขียนติด ๆ กันไม่มีการแบ่งคำอย่างชัดเจนทำให้การอ่านภาษาไทยผู้อ่านต้องใช้ความหมายของคำในการตัดสินการอ่านแบ่งคำตามความเหมาะสมเช่นคำว่า "ตากลม" อาจอ่านเป็น "ตาก-ลม" ก็ได้ หรืออ่านเป็น "ตา-กลม"ก็ได้ ดังนั้นการเขียน Regex เพื่อทำการตรวจสอบอาจช่วยได้ระดับหนึ่ง อ่าจมีผิดบ้างถูกบ้าง แต่ก็ถือว่าเป็นเครื่องมือที่ใช้ช่วยเหลือในการตรวจสอบเพิ่มเติมได้ 80% ของความเป็นไปใด้ก็แล้วกันนะครับ หวังว่าการเขียนเพิ่มเติมส่วนนี้ จะมีประโยชน์บ้างไม่มากก็น้อย
Submitted by อธิปัตย์ ล้อวงศ์งาม
1

Regex for Matching Documentation Websites

Created·2024-11-24 01:45
Flavor·JavaScript
Regex for Matching Documentation Websites This repository contains a powerful regular expression designed to match URLs that commonly point to documentation-related websites. The regex is optimized for flexibility, covering various terms and URL patterns. Regex Pattern ^.(?:\.|\/)(docs|documentation|help|guide|manual|reference|api|kb|support|resources|wiki|developer|how-to|tutorials|examples|learn|instructions)(?:\.|\/)?.$ Purpose This regex is intended to identify URLs that contain keywords associated with documentation or support websites. It handles common patterns in subdomains, directories, and file paths. Explanation ^.*: Matches any characters at the beginning of the URL (any prefix). (?:\.|\/): Matches either a period (.) or a forward slash (/) preceding the keyword. (docs|documentation|help|guide|manual|...): Matches any of the keywords listed in the group. (?:\.|\/)?: Allows an optional period (.) or forward slash (/) following the keyword. .*$: Matches any characters following the keyword (any suffix). Examples Positive Examples The following URLs should match the regex: https://example.com/docs http://docs.example.com https://example.com/documentation https://sub.domain.com/docs/index.html https://example.com/help https://api.example.com/docs http://example.com/manual/index.html https://wiki.example.com http://developer.example.com/guide https://example.com/tutorials/docs/page https://kb.example.com/docs/tutorial.html https://example.com/resources/documentation/tutorial.html http://example.com/reference/help/documentation.html https://developer.example.com/docs/tutorials/index.html http://support.example.com/documentation/overview https://resources.example.com/docs/v1/tutorial https://example.com/how-to/documentation http://example.com/api/reference/docs https://example.com/reference/v2/index.html http://example.com/docs/resources/api.html Negative Examples The following URLs should not match the regex: https://example.com/documentary http://helpful.example.com https://manuals.example.com http://example.com/references https://example.com/resourceful http://example.com/wiki-books https://apiary.example.com http://example.com/documents http://example.com/documentable https://help-center.example.com http://manual.example.com/docsystem https://example.com/resourcesful http://api.example.comary https://example.net/instructions-v1 http://example.org/learned-tutorial http://example.com/support-center Author Jeremy Georges-Filteau Website Github
Submitted by jgeofil

Community Library Entry

36

Regular Expression
Created·2015-01-23 16:47
Updated·2023-07-19 08:36
Flavor·PCRE (Legacy)

/
(?(DEFINE) (?P<ver>\d+(?:\.\d+)*(?![.\d])) (?P<agent>Mozilla\/(?&ver)) (?P<os>(?&os_windows)|(?&os_linux)|(?&os_macintosh)|(?&os_ios)) (?P<os_windows>Windows[ ]\w+[ ](?&ver)) (?P<os_linux>Linux(?:[ ](?:i686|x86_64))?) (?P<os_macintosh>Macintosh) (?P<os_ios>(?:CPU[ ])?iPhone[ ]OS|CPU[ ]OS.*?like[ ]Mac[ ]OS[ ]X) (?P<device>(?&device_ios)|(?&device_firefox)|(?&device_android)) (?P<device_ios>iPhone|iPad) (?P<device_firefox>Mobile) (?P<device_android>Android(?:[ ](?&ver))?) (?P<browser> (?: (?&browser_ie) | (?&browser_safari) | (?&browser_chrome) | (?&browser_chromium) | (?&browser_firefox) | (?&browser_version) # | (?&browser_nexus) | (?&browser_mobile) | (?&browser_gsa) | (?&browser_quicklook) | (?&browser_opera) ) [ \/] (?: [A-Z\d]+\b(?!\.) | (?&ver) ) ) (?P<browser_safari>(?:Mobile[ ])?Safari) (?P<browser_chrome>Chrome) (?P<browser_chromium>\b\w+\b[ ]Chromium) (?P<browser_firefox>Firefox) (?P<browser_ie>MSIE) (?P<browser_version>Version) (?P<browser_nexus>Nexus[ ]\d+[ ]Build) (?P<browser_mobile>Mobile) (?P<browser_gsa>GSA) (?P<browser_quicklook>QuickLook) (?P<browser_opera>OPR) ) ^ (?:(?=.*?(?P<Agent>(?&agent)))) (?:(?=.*?(?P<OS>(?&os)))) (?:(?=.*?(?P<Device>(?&device))))? (?:(?=.*?(?P<Browser>(?&browser)(?:[ ](?&browser))*)))?
/
gmx
Open regex in editor

Description

From a (fairly large) list of User Agent strings, extract the OS, Browser, and Device Type.

Submitted by OnlineCop