'%s' % 100000
ได้รับการประเมินโดยคอมไพลเลอร์และเทียบเท่ากับค่าคงที่ ณ รันไทม์
>>> import dis
>>> dis.dis(lambda: str(100000))
8 0 LOAD_GLOBAL 0 (str)
3 LOAD_CONST 1 (100000)
6 CALL_FUNCTION 1
9 RETURN_VALUE
>>> dis.dis(lambda: '%s' % 100000)
9 0 LOAD_CONST 3 ('100000')
3 RETURN_VALUE
%
ด้วยนิพจน์รันไทม์ไม่ (อย่างมีนัยสำคัญ) เร็วกว่าstr
:
>>> Timer('str(x)', 'x=100').timeit()
0.25641703605651855
>>> Timer('"%s" % x', 'x=100').timeit()
0.2169809341430664
โปรดทราบว่าstr
ยังช้ากว่าเล็กน้อยตามที่ @DietrichEpp กล่าวเนื่องจากstr
เกี่ยวข้องกับการค้นหาและการเรียกใช้ฟังก์ชันในขณะที่%
คอมไพล์เป็นรหัสไบต์เดียวทันที:
>>> dis.dis(lambda x: str(x))
9 0 LOAD_GLOBAL 0 (str)
3 LOAD_FAST 0 (x)
6 CALL_FUNCTION 1
9 RETURN_VALUE
>>> dis.dis(lambda x: '%s' % x)
10 0 LOAD_CONST 1 ('%s')
3 LOAD_FAST 0 (x)
6 BINARY_MODULO
7 RETURN_VALUE
แน่นอนข้างต้นเป็นจริงสำหรับระบบที่ฉันทดสอบ (CPython 2.7); การใช้งานอื่น ๆ อาจแตกต่างกัน
'{}'.format(100000)