所有题目来自Python123网站。
时间函数的使用还是需要多加练习,这里用到了time.perf_count()且两次调用求出时间差,time.sleep()则是直接设置程序休眠时间。
import time
scale = 50
print("执行开始".center(scale//2,'-'))
start = time.perf_counter()
for i in range(scale+1):
a = i*'*'
b = (scale-i)*'.'
c = i/scale*100
d = time.perf_counter()-start
print("\r{:^3.0f}%[{}->{}]{:.2f}s".format(c,a,b,d),end="")
time.sleep(0.1)
print("\n"+"执行结束".center(scale//2,'-'))
这题有个很巧妙的地方,通过利用print中{}的顺序嵌套来完成*号的对齐。
n = eval(input())
for i in range(1,n+1,2):
print("{0:^{1}}".format('*'*i, n))
这题有意思的是字符之间的之间大小比较,而不是将其转换为Unicode码在进行比较。对于字符和Unicode之间的转换主要就是chr()和ord()这两个函数。
s = input()
t = ""
for i in s:
if 'a'<= i <= 'z':
t += chr(ord('a')+(ord(i)+3-ord('a'))%26)
elif 'A'<= i <='Z':
t += chr(ord('A')+(ord(i)+3-ord('A'))%26)
else:
t +=i
print(t)
这题主要还是熟练掌握print里{}中的输出含义,对对齐方式、补充符号、输出宽度和保留小数的写法及顺序需要熟记。
t =pow(eval(input()),0.5)
print("{:+>30.3f}".format(t))
split为分隔符,后面的()的字符为分割字符,以此将之前的字符串分割成若干字符。
str = input().split('-')
print(str[0]+'+'+str[-1])