一個函數形如
(operator arg1 arg2 ... argn)
即操作符號,參數1參數2一直到參數n。其中參數本身也可以是這樣格式的函數。
例如這樣一串字串
String="(add (add 1 2) (mul 2 1) 2 )"
要把它的運算元和參數分割出來,也就是分割成
["add","(add 1 2)","(mul 2 1)","2"]
這樣的字元數組,該如何分割?
目前我的做法是每次先把最外邊的括號去掉,然後想用空格分割字串,可是這樣中間的空格也會成為要分割的地方。如果用正規表示式,因為每一個參數內部還是可能嵌套括號,這種情況該如何匹配?
仅有的幸福2017-06-23 09:15:59
前綴表示法
, S-表達式
,Lisp表達式
lisp的S-表達式
是多層嵌套的樹形結構,比較接近抽象語法樹(AST)
。
正規如果沒有遞迴語法的話,很難解析S-表達式
。
下面是個python的簡單例子,我做了註釋,應該很容易理解。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
1 2 3 4 |
|
S-expression
阿神2017-06-23 09:15:59
正規:
1 |
|
注意,此正規則帶有Global參數
如果arg1, arg2, arg3, ... argn
中巢狀(op arg ...)
只有一層的話,可以用這個方法