有效電話號碼-leetcode


有效電話號碼


shell 編程題目
考察了很多方面的內容

  1. shell 命令 grep | sed | awk
  2. 正則表達式
  3. shell 的轉義處理

1. 地址

https://leetcode-cn.com/problems/valid-phone-numbers/

2. 解法

你可以假設一個有效的電話號碼必須滿足以下兩種格式: (xxx) xxx-xxxx 或 xxx-xxx-xxxx。(x 表示一個數字)
分析題目,發現兩種格式有一個共同的部分,可以表示成

\d{3}-\d{4}$

不同的部分可以表示成

$\(\d{3}\)\s
或者
$\d{3}-

解釋:

  1. \d 代表匹配數字,{3} 代表匹配多少次數字
  2. \s 表示空白字符
grep -P "^(\(\d{3}\)\s|\d{3}-)(\d{3}-)\d{4}$" file.txt

這里要注意,在 linuxshell 中普通的 grep 或者 egrep 是不支持 \d 這種縮略形式的,必須使用 [0-9] 代表數字

如果需要使用 \d 那么必須指定 -P 選項,代表指定 perl 形式的正則表達式,這個需要讀者自行查閱資料看一下不同標准的正則的異同點。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM