python流程控制
****************************************with语句*******************************************
with expression as target:
with-body
import os,sys os.chdir(sys.path[0]) #os.getcwd() #执行命令的位置 /sys.path[0] #当前工作目录 with open('message.txt','r',encoding='utf-8') as obj_file:#将打开文本作为一个对象 print(obj_file.read()) print("with内关闭了吗?",obj_file.closed) print("with外关闭了吗?",obj_file.closed) #退出时自动关闭
****************************************异常 try / raise 语句*******************************************
#raise [ExceptionName[(reason)]] 可能产生异常但不在程序中处理此异常,raise后面的程序也不会继续执行。可使用try 语句捕获异常信息再处理。注:原因可以忽略不写
try:
do something
except errorno as err1:
print('错误码:', err1)
except TimeoutError as err2:
print('错误码:', err2)
else:
print('没有错误!!!')
finally:
do something #最终必然执行的动作
def division(): apple_num=int(input('请输入苹果的个数:')) children_num=int(input('请输入小朋友的个数:')) resoult=apple_num//children_num #计算每个人能分几个苹果 remain=apple_num-resoult*children_num #剩余几个苹果 if apple_num < children_num: raise ValueError('苹果太少了不够分!!!') if remain>0 : print('每个人分得:',resoult,'\n剩余:',remain) else: print('没有剩余') if __name__ == '__main__': mylogger = Mylogging("log.log").logger try: division() except(ZeroDivisionError,ValueError) as e: mylogger.error('错误信息:{}'.format(e),exc_info = True)
案例2
mylogger = Mylogging("log.log").logger #import logger_class try: open("message.txt","rb") mylogger.info("message.txt exist") except (SystemExit,KeyboardInterrupt): raise except Exception: mylogger.error("Faild to open sklearn.txt from logger.error",exc_info = True) #exc_info打开会打印错误,False则不打印 else: mylogger.info('no capture errer!') finally: mylogger.info('finish')
while 的玩法
tag=True while tag: choice=input('level_1 >> ').strip() if choice == 'quit': break #quit推出单层 if choice == 'quit_all': tag = False #改变tag来退出所有循环 while tag: choice=input('level_2 >> ').strip() if choice=='quit':break if choice == 'quit_all': tag = False while tag: choice = input('level_3 >> ').strip() if choice == 'quit': break if choice == 'quit_all': tag=False

浙公网安备 33010602011771号