国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

java - 如何分割形如(operator arg1 arg2 ... argn)的字符串?

瀏覽:87日期:2023-10-27 11:12:36

問題描述

一個函數形如(operator arg1 arg2 ... argn)即操作符號,參數1參數2一直到參數n。其中參數本身也可以是一個這樣格式的函數。比如這樣一串字符串String='(add (add 1 2) (mul 2 1) 2 )'要把它的操作數和參數分割出來,即分割成

['add','(add 1 2)','(mul 2 1)','2']

這樣的字符數組,應該如何分割?

目前我的做法是每次先把最外邊的括號去掉,然后想用空格分割字符串,可是這樣中間的空格也會成為要分割的地方。如果用正則表達式,因為每一個參數內部還是可能嵌套括號,這種情況應該如何匹配呢?

問題解答

回答1:

前綴表示法, S-表達式,Lisp表達式

lisp的S-表達式是多層嵌套的樹形結構,比較接近抽象語法樹(AST)。

正則如果沒有遞歸語法的話,很難解析S-表達式。

下面是個python的簡單例子,我做了注釋,應該很容易理解。

def parse_sexp(string): sexp = [[]] word = ’’ in_str = False #是否在讀取字符串 for char in string: # 遍歷每個字符if char == ’(’ and not in_str: # 左括號 sexp.append([])elif char == ’)’ and not in_str: # 右括號 if word:sexp[-1].append(word)word = ’’ temp = sexp.pop() sexp[-1].append(tuple(temp)) # 形成嵌套elif char in ’ nt’ and not in_str: # 空白符 if word:sexp[-1].append(word)word = ’’elif char == ’'’: # 雙引號,字符串起止的標記 in_str = not in_strelse: word += char # 不是以上的分隔符,就是個合法的標記 return sexp[0]

>>> parse_sexp('(+ 5 (+ 3 5))')[(’+’, ’5’, (’+’, ’3’, ’5’))]>>> parse_sexp('(add (add 1 2) (mul 2 1) 2 )')[(’add’, (’add’, ’1’, ’2’), (’mul’, ’2’, ’1’), ’2’)]

S-expression

回答2:

正則:

(s*w+(s+d+)+s*)|w+|d+

注意,此正則帶有Global參數

如果arg1, arg2, arg3, ... argn中嵌套(op arg ...)只有一層的話,可以用這個方法

java - 如何分割形如(operator arg1 arg2 ... argn)的字符串?

標簽: java
相關文章:
主站蜘蛛池模板: 99视频在线看 | 日韩三级在线播放 | 国产精品99在线观看 | 久草手机视频在线观看 | 日韩成人免费一级毛片 | 久久一本色系列综合色 | 国产美女精品视频 | 国产欧美亚洲三区久在线观看 | 亚洲美女色成人综合 | 韩国美女爽快一级毛片黄 | 欧美大胆一级视频 | 欧美与黑人午夜性猛交久久久 | 国产高清一级毛片在线不卡 | 久久久久女人精品毛片九一 | 夜色www国产精品资源站 | 久久精品国产亚洲 | 欧美精品午夜久久久伊人 | 国产乱子视频 | 高清国产美女一级a毛片录 高清国产亚洲va精品 | 国产成人精品曰本亚洲 | 大陆老头xxxxxhd| 欧美一级片在线免费观看 | 美女扒开双腿让男人爽透视频 | 精品国产一区二区三区在线 | 成人欧美一区二区三区视频xxx | 九九欧美 | 亚洲依依成人综合在线网址 | 久久香蕉精品成人 | 久久精品二三区 | 日韩欧美一区二区在线观看 | 国产亚洲精品久久麻豆 | 欧美精品网址 | 国产二区三区毛片 | 国产无限制自拍 | 偶偶福利影院 | gogo999亚洲肉体艺术大胆 | 久艹视频在线 | 九九久久精品视频 | 国产三级精品91三级在专区 | 国产情侣普通话刺激对白 | 国产三级小视频 |