字符串字面值
字符串 : [前缀](长字符串 | 短字符串)
前缀 : "r" | "u" | "R" | "U" | "f" | "F"
| "fr" | "Fr" | "fR" | "FR" | "rf" | "rF" | "Rf" | "RF"
长字符串 :'长字符串item' | "长字符串item"
短字符串 :'短字符串item' | "短字符串item"
长字符串item :长字符char | stringescapeseq
短字符串item :短字符char | stringescapeseq
长字符char :除了'\'外任何字符
短字符char :除了'\'外任何字符 or 新行 or 引用
stringescapeseq : "\" <任何字符>
格式字符串字面值
格式化字符串 :
(字面量 |"{{"|"}}"|替换域)*
替换域:
{ 格式化表达式 [=] [! 转化标志] [: 格式] }
格式表达式 :
(条件表达式 | * or_expr) (, 条件表达式 | , * or_expr)* [,] | yield_expression
转化标志:
"s" | "r" | "a"
格式:
(字面量 | NULL | 替换域)
字面量:
除了NULL '{' '}' 的 code point
eg
>>> today = datetime(year=2017, month=1, day=27)
>>> f"{today:%B %d, %Y}" # using date format specifier
'January 27, 2017'
>>> foo = "bar"
>>> f"{ foo = }" # preserves whitespace
" foo = 'bar'"
整数字面值
整数 : 十进制 | 二进制 | 八进制 | 十六进制
十进制: 非0单个数字 ([_] 单个数字)* | 0 + ([_] 0)*
二进制: 0 (b | B) ([_] 二进制数字)+
八进制: 0 (o | O) ([_] 八进制数字)+
十进制: 0 (x | X) ([_] 十进制数字)+
确定数值时,会忽略字面值中的下划线。下划线只是为了分组数字,让数字更易读。
浮点数字面值
浮点数: 浮点 | 指数浮点
浮点: [整数部分] 分数 | 整数部分 .
指数浮点: (整数部分 | 浮点) 指数
整数部分: 整数 ([_] 整数)*
分数: . 整数部分
指数: (e | E) [+ | -] 整数部分
参考 https://docs.python.org/zh-cn/3/reference/lexical_analysis.html