請教python編碼風格和異常處理問題
問題描述
請教各位個問題,編寫web應用注冊模塊,如下面這段代碼,服務端需要檢測用戶的傳遞的參數。下面幾種寫法哪個更好,異常處理方式是否正確,或者各位是否有更好的方式呢
def check_args(account, passwd, birthday, name): # 第一種寫法 if account == ’’ or not isinstance(account, str):raise ValueError if passwd == ’’ or not isinstance(passwd, str):raise ValueError if birthday == ’’ or not isinstance(birthday, str):raise ValueError if name == ’’ or not isinstance(name, str):raise ValueError # 第二種寫法 if (account == ’’ or not isinstance(account, str)) or (passwd == ’’ or not isinstance(passwd, str)) or (birthday == ’’ or not isinstance(birthday, str)) or (name == ’’ or not isinstance(name, str)):raise ValueError return Nonedef user_register(form): account = form['account'] passwd = form['passwd'] birthday = form['birthday'] name = form['name'] # 異常放在這一層,但在main函數調用 user_register 如何檢測是否成功呢 # 是當前異常繼續向外拋,還是通過返回值 try:check_args(account, passwd, birthday, name)insertUserInfo(account, passwd, birthday, name) except ValueError:pass except MySQLError:pass except Exception:pass
問題解答
回答1:既然是web應用,你應該把這些驗證抽象出來,自己寫驗證模塊或者用別人的驗證模塊
回答2:為什么不樸素的返回一個True or False呢,異常一般是指程序出現了錯誤,但注冊信息不合法并不帶表程序出了錯,所以用條件判斷返回真假值就可以了。另外一般來說表單的合法判斷在前端處理比較好。
相關文章:
1. 查詢mysql數據庫中指定表指定日期的數據?有詳細2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
