Python實(shí)現(xiàn)通訊錄功能
說實(shí)話,第一次寫這么長的Python代碼,期間遇到了很多問題,但是,最終還是完成了,花了我一天半的時(shí)間。
該程序?qū)崿F(xiàn)了用戶的增,刪,改,查,主要用到sqlite3模塊。對(duì)于該模塊的知識(shí)點(diǎn),請(qǐng)查看我的另一篇文章SQLite-Python
如有更好的建議,請(qǐng)私信,本人將不勝榮幸,讓我們一起來學(xué)習(xí)Python!
#-*- coding:utf-8 -*-
import sqlite3
#打開本地?cái)?shù)據(jù)庫用于存儲(chǔ)用戶信息
conn = sqlite3.connect('mysql_person.db')
#在該數(shù)據(jù)庫下創(chuàng)建表,創(chuàng)建表的這段代碼在第一次執(zhí)行后需要注釋掉,否則再次執(zhí)行程序會(huì)一直提示:該表已存在
conn.execute('''CREATE TABLE MT
(ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL);''')
print "Table created successfully";
conn.close()
#增加用戶信息
def insert():
ID = input('請(qǐng)輸入用戶ID:\n')
NAME = raw_input('請(qǐng)輸入用戶昵稱:\n')
AGE = input('請(qǐng)輸入年齡:\n')
ADDRESS = raw_input('請(qǐng)輸入用戶地址:\n')
SALARY = input('請(qǐng)輸入用戶薪水:\n')
sql1 = 'insert into MT(ID,NAME,AGE,ADDRESS,SALARY)'
sql1 += 'values("%d","%s","%d","%s","%d");'%(ID,NAME,AGE,ADDRESS,SALARY)
conn.execute(sql1)
conn.commit()
print "Records insert successfully"
#刪除用戶信息
def delete():
name = raw_input("請(qǐng)輸入所要?jiǎng)h除的聯(lián)系人姓名:")
cursor = conn.execute("SELECT name from MT where name = '%s';"%name)
for row in cursor:
if name == row[0]:
conn.execute("DELETE from MT where name = '%s';"%name)
conn.commit()
print "Records delete successfully"
break
else:
print "sorry,不存在該用戶"
#修改用戶信息
def modify():
name = raw_input("請(qǐng)輸入要修改用戶的姓名:")
print search()
sql4 = "SELECT id, name, age,address, salary from MT where name = '%s';"%name
cursor = conn.execute(sql4)
x = raw_input("請(qǐng)輸入要修改用戶的新地址:")
y = input("請(qǐng)輸入要修改用戶的新年齡:")
z = input("請(qǐng)輸入要修改用戶的新薪水:")
sql3 = "UPDATE MT set address = '%s',age = '%d',\
salary = '%d' where name = '%s';"%(x,y,z,name)
conn.execute(sql3)
conn.commit()
print "修改成功"
sql5 = "SELECT id, name, age,address, salary from MT where name = '%s';"%name
cursor = conn.execute(sql5)
for row in cursor:
print "ID = ", row[0]
print "NAME = ", row[1]
print "AGE = ",row[2]
print "ADDRESS = ", row[3]
print "SALARY = ", row[4], "\n"
#查詢用戶信息
conn = sqlite3.connect('mysql_person.db')
def search():
conn = sqlite3.connect('mysql_person.db')
name = raw_input('請(qǐng)輸入要查詢的用戶姓名')
sql2 = "SELECT id,name,age, address, salary from MT where name= '%s';" % (name)
cursor = conn.execute(sql2)
for row in cursor:
print "ID = ", row[0]
print "NAME = ", row[1]
print "AGE = ",row[2]
print "ADDRESS = ", row[3]
print "SALARY = ", row[4], "\n"
break
else:
print "sorry,沒有該用戶信息"
#顯示所有用戶信息
def showall():
cursor = conn.execute("SELECT id, age, name, address, salary from MT")
for row in cursor:
print "ID = ", row[0]
print "NAME = ", row[1]
print "AGE = ",row[2]
print "ADDRESS = ", row[3]
print "SALARY = ", row[4], "\n"
print "Operation done successfully";
cursor = conn.execute("select count(*) from MT;")
for row in cursor:
print "一共有%d個(gè)用戶"%row[0]
def menu():
print '1.新增聯(lián)系人'
print '2.刪除聯(lián)系人'
print '3.修改聯(lián)系人'
print '4.查詢聯(lián)系人'
print '5.顯示所有聯(lián)系人'
print '6.退出程序'
print 'What do you want to do?'
while True:
menu()
x = raw_input('請(qǐng)輸入您的選擇菜單號(hào):')
if x == '1':
insert()
continue
if x == '2':
delete()
continue
if x == '3':
modify()
continue
if x == '4':
search()
continue
if x == '5':
showall()
continue
if x == '6':
print "謝謝使用!"
exit()
continue
else:
print "輸入的選項(xiàng)不存在,請(qǐng)重新輸入!"
continue
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python實(shí)現(xiàn)通訊錄管理系統(tǒng)
- python實(shí)現(xiàn)通訊錄系統(tǒng)
- 如何用Python寫一個(gè)簡單的通訊錄
- python實(shí)現(xiàn)學(xué)生通訊錄管理系統(tǒng)
- python數(shù)據(jù)庫編程 Mysql實(shí)現(xiàn)通訊錄
- python數(shù)據(jù)庫編程 ODBC方式實(shí)現(xiàn)通訊錄
- python實(shí)現(xiàn)手機(jī)通訊錄搜索功能
- Python實(shí)現(xiàn)命令行通訊錄實(shí)例教程
- 一個(gè)簡單的python程序?qū)嵗?通訊錄)
- python實(shí)現(xiàn)簡單通訊錄管理系統(tǒng)
相關(guān)文章
python3.x+pyqt5實(shí)現(xiàn)主窗口狀態(tài)欄里(嵌入)顯示進(jìn)度條功能
這篇文章主要介紹了python3.x+pyqt5實(shí)現(xiàn)主窗口狀態(tài)欄里(嵌入)顯示進(jìn)度條功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07
利用Python批量提取Win10鎖屏壁紙實(shí)戰(zhàn)教程
這篇文章主要給大家介紹了關(guān)于利用Python批量提取Win10鎖屏壁紙的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03
Python編程批量實(shí)現(xiàn)md5加密pdf文件
這篇文章主要介紹了Python編程批量實(shí)現(xiàn)md5加密pdf文件,文章基于python的相關(guān)資料展開詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下2022-04-04
pytest解讀fixtures之Teardown處理yield和addfinalizer方案
這篇文章主要為大家介紹了pytest解讀fixtures之Teardown處理yield和addfinalizer的方案實(shí)例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06

