我的提取字符串的token函数是:
def t_STRING(t): r'\"([^\"]|\\.)*\"' t.value = t.value[1:-1] return t
有个办法是:
t.value=t.value.decode("string-escape")
但是这样并不能处理
\n, \t ,等复杂些的和自定义的转义
根据此文http://inst.eecs.berkeley.edu/~cs164/sp10/TA.d/flex-start-conditions.html,貌似应该用state.
怎么用ply来做这个事情呢 ?
来自 ANSIC grammer