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

1

Regular Expression
Created·2024-01-31 18:12
Flavor·PCRE2 (PHP)

/
(?:(?'Key'[^\n][\w|\s]*)=(?'Value'[^;'"",`\n]+);?)
/
gm
Open regex in editor

Description

Parses connection strings into named groups Key and Value , which can then be handled by whatever programmatic method you like. Ideally handled as key value pairs.

I did this in PowerShell using the below:


function Resolve-ConnectionString {
  param(
    [string]$ConnectionString,
    [string[]]$IncludeKeys = @(),
    [switch]$HideSensitiveValues,
    [switch]$AsObject
  )
  begin {
    Write-Debug "Enter [$($PSCmdlet.MyInvocation.MyCommand.Name)]..."
    $PSBoundParameters.Keys.ForEach{
      if ($PSBoundParameters.PSItem -is [string]) {
        Write-Debug "$_ : $($PSBoundParameters.Item($_))"
      } else {
        Write-Debug "$_ : $($PSBoundParameters.Item($_).GetType())"
      }
    }
    $SensitiveValueKeys = [System.Collections.Generic.List[string]]::new([string[]]@(
        'AccountKey',
        'Password',
        'SharedAccessKey',
        'SharedAccessSignature',
        'Token',
        'PAT',
        'PersonalAccessToken',
        'AccessToken'
      ))
    # Example Connection Strings
    #     $testcontent2 = @"
    # AccountEndpoint=https://some-base-name.documents.azure.com:443/;AccountKey=kascuh9823nfsdvxc==;
    # Endpoint=sb://other-more-different-name.servicebus.windows.net/;SharedAccessKeyName=mysak-name;SharedAccessKey=msd8fs2bsc==;EntityPath=someentitypath;TransportType=Amqp
    # Data Source=myServerName.whatever.local;Initial Catalog=MyDatabaseName;Persist Security Info=True;User ID=myUserId;Password=MyBadPractice;MultipleActiveResultSets=True;MultiSubnetFailover=True;
    # "@
    $regexString = "(?:(?'Key'[^""\n][\w|\s]*)=(?'Value'[^;'"",`\n]+);?)"
  }
  process {
    if ($AsObject) {
      $output = [PSCustomObject]::new()
    } else {
      $output = @{}
    }
    if ($IncludeKeys.Count -gt 0) {
      $IncludeKeys.ForEach{
        Write-Debug "Adding key [$PSItem] to list of sensitive keys"
        $SensitiveValueKeys.Add($PSItem)
      }
    }
    Write-Debug "SensitiveValueKeys Count: $($SensitiveValueKeys.Count)"
    [regex]::Matches($ConnectionString, $regexString).foreach{
      $Key = $PSItem.Groups.Where({ $PSItem.Name -eq 'Key' })[0].Value
      $Value = $PSItem.Groups.Where({ $PSItem.Name -eq 'Value' })[0].Value
      Write-Debug "Key: [$($Key)]"
      Write-Debug "Value: [$($Value)]"
      $keyIsSensitive = ($SensitiveValueKeys | ForEach-Object {
          $Key -like "*$PSItem*"
        }).Contains($true)
      Write-Debug "Key is sensitive: [$($keyIsSensitive)]"
      if ($HideSensitiveValues -and $keyIsSensitive) {
        $Value = '********'
      } elseif ($keyIsSensitive) {
        Write-Warning "The value of [$($Key)] is sensitive and will be included in the output!!!"
      }
      if ($AsObject) {
        $output | Add-Member -MemberType NoteProperty -Name $Key -Value $Value -Force
      } else {
        $output.$Key = $Value
      }
    }
  }
  end {
    $output
    Write-Debug "Exit [$($PSCmdlet.MyInvocation.MyCommand.Name)]..."
  }

}

Submitted by rbleattler