我正在構建一個簡單的程序,以便爲我的租賃屬性預先篩選租戶。程序詢問他們一系列問題 - 其中一些問題需要一個「是」或「否」的答案,這將是一個布爾(真/假)。使用python輸入布爾值
問題是,無論您爲布爾輸入回答什麼,它都會記錄爲「1」。
我使用本地sqlite3的來存儲數據,下面的代碼:
def enter_dynamic_data():
fname = input("First Name? ")
lname = input("Last Name? ")
email = input("Email? ")
phone = input("Phone? ")
criminal = bool(input("Have you ever been convicted of a crime? "))
evicted = bool(input("Have you ever been evicted? "))
income = bool(input("Do you have verifiable income of at least 3x the rent amount? "))
ref = bool(input("Do you have good rental references? "))
c.execute("INSERT INTO tenant_screening (firstname, lastname, email, phone, criminal, evicted, income, ref) VALUES (?, ?, ?, ?, ?, ?, ?, ?)", (fname, lname, email, phone, criminal, evicted, income, ref))
這是因爲bool()函數評估一切爲真(1),除了像空列表/元組,空,假或空字符串的東西。說布爾(「任何」)總是評估爲真,因爲有什麼。 – Nf4r
幾乎重複的是,sqllite3布爾被存儲爲0,1。* SQLite沒有單獨的布爾存儲類*。 [doc](http://www.sqlite.org/datatype3.html)僅供參考 – idjaw
就像:answer = input()。lower()==「yes」;.您還可以執行其他檢查:answer = int(input())> 100;等等.. – dinomoth