این مقاله یکی از قسمتهای سلسله مقالاتی برای آشنایی و آموزش زبان پایتون است. این مجموع پیش از این در ماهنامه شبکه منتشر شده اما به سایت جدید منتقل نشده بود. با توجه به اهمیت موضوع و درخواستهای مکرر خوانندگان، این مجموعه را به سایت مجله اضافه میکنیم و امیدواریم که مورد توجه علاقمندان قرار بگیرد.
برای مطالعه قسمتهای قبلی سلسله مقالات آموزش زبان برنامهنویسی پایتون اینجا کلیک کنید
فهرست 1- چهارچوب كلی برنامه Cook Book
def __init__(self):
global connection
global cursor
self.totalCount=0
connection = apsw.Connection(“cookbook1.db3”)
cursor=connection.cursor()
فهرست 2- كدهای تكميل تابع راهاندازی كلاس Cook Book
def All(self):
print “\n\nNumber \tName \t\tServes \t\tSource”
print “-”*55
sql = “SELECT * FROM Recipes”
cntr=0
for x in cursor.execute(sql):
cntr += 1
print “%s \t%s \t%s \t\t%s” %(x[0],x[1],x[2],x[3])
print “-”*55
self.totalCount = cntr
print “Total number of items: %s” %cntr
فهرست 3- كدهای تابع نمايش تمام موارد موجود در پايگاه داده
همچنین برای نگهداری روالهای مربوط به پایگاه داده یک کلاس تعریف خواهیم کرد. چون این کد بسیار طولانی خواهد بود ما در ابتدا چهارچوب کلی آن را نوشته و سپس قسمتهای مختلف را به تدریج به آن میافزاییم. برای شروع كار این چهارچوب را که در فهرست 1 آورده شده، وارد کرده و آن را با نام CookBook.py ذخیره کنید.
همانطور که در این کد مشاهده میکنید، کلیت یک کلاس و تابعی برای ترسیم یک منو روی صفحه نمایش تعریف شده است. ما به تدریج این چهارچوب را برای رسیدن به برنامه نهایی تکمیل خواهیم کرد. اگر در وضعیت فعلی برنامه را اجرا کنید، شکلی همانند شكل 1 را مشاهده خواهید کرد. در این حالت، تنها کلید 0 برای خروج از برنامه کار خواهد کرد. اکنون به نوشتن روتین راهاندازی کلاس و سایر روتینهای مربوط به اعمال نمایشکل اطلاعات، جستوجو، نمایش یک مورد، افزودن و حذف موارد پایگاه داده خواهیم پرداخت. از میان این روتینها، روتینهای نمایش کل اطلاعات، جستوجو و افزودن آیتم به هیچ آرگومان ورودی نیاز ندارند (البته همانطور که از بحثهای کلاسها و اشیاء به یاد دارید، به جزء آرگومان اجباری self). اما روتینهای نمایش و حذف به پارامتری نياز دارند که در این کدها آن را which نامیدهایم و این پارامتر تعیین میکند کدام آیتم باید نمایش دادهشده یا حذف شود.
راهاندازی
در ابتدا باید روتین راهاندازی کلاس یا __init__ را کامل کنیم. کدهای مورد نیاز برای این روتین در فهرست 2 آورده شده است. اين كد را جايگزين خطوط 5 و6 فهرست 1 كنيد.
در اینجا ابتدا دو متغیر جهانی تعریفکردهایم. این متغیرها به رغم اینکه در تعریف یک تابع آورده شدهاند، بهواسطه کلمه global، در تمام برنامه قابل استفادهخواهند بود. این کار را به این دلیل انجام میدهیم که پایگاه داده و مکاننمای مربوط به آن در تمام روتینهای برنامه قابل دسترس باشند. برای کار با پایگاه دادهای که در قسمت قبل ایجاد کردید، باید این برنامه و فایل پایگاهداده را در یک پوشه و در کنار هم قرار دهید و در خط 5، نام فایل پایگاه داده خود را جایگزین cookbook1.db3 کنید.
نمایش همه موارد
برای نمایش همه موارد از کد فهرست3 استفاده خواهیم کرد. این کد را در کلاس CookBook فهرست1 جایگزین خطوط 7 و 8 کنید. همینطور باید از خط 34 فهرست 3 کلمه pass را حذف و عبارت زير را جایگزین آن کنید:
ckb.All()
temp = raw_input(“Press any key\ to continue...”)
در این تابع ما از cursor ساخته شده در روتین __init__ استفاده کردهایم و تمام محتویات جدول Recipes را فراخوانی کردهایم، سپس در یک حلقه تمام مقادیر را با قالببندیهای استفاده شده در دستور print (که قبلاً با آن آشنا شدهاید) بهصورت منظم چاپ کردهایم. به یاد دارید که apsw مقادیر برگشتی جدول را به صورت توپل به ما بازمیگرداند، به همین دلیل، ما از [x[0 و [x[1 و... استفاده کردهایم. در انتهای این روتین و در خط 11 تعداد کل آیتمهای موجود در جدول Recipes را نیز اعلام کردهایم.
شکل 1- منوی دسترسی به پايگاه داده
جستوجو
برای بخش جستوجو، به دلیل کمبود فضا، تنها بخش جستوجوی نام دستورالعمل را پیادهسازی کردهایم و جستوجو بر اساس محتویات و تعداد نفراتی را که با یک دستورالعمل سير میشوند، به عهده شما گذاشتهایم. کدهای این روتین در فهرست 4 آورده شده است. اين كدها را جايگزين خطوط 9 و 10 فهرست كنيد.
در این کد و در خط 5 عبارت موردنظر از کاربر پرسیده شده و در خط 6 با تعریف یک دستور sql عملیات جستوجو را روی پایگاه داده انجامدادهایم. شاید عبارت %%%s%% در این خط کد عجیب به نظربرسد. در زبان sql برای تعریف مشابهت از کلمه کلیدی like و فرم %term% استفاده میشود. در این حالت کلماتی که مشابه term باشند، برگردانده میشوند. اما چون در زبان پایتون از علامت % برای فرمتکردن رشتهها استفاده میشود، یک رشته نمیتواند به طور مستقیم شامل علامت % باشد. برای درج این علامت در یک رشته باید دوبار آن را پشت سر هم (%%) بهکار ببریم. به این ترتیب، در خط 7 جفت علامتهای سمت راست و چپ به تک علامتهای % و قسمت وسط (%s) نیز توسط عبارت term جایگزینمیشود. در انتهای این روتین و در خط 9 از تابع ()Show که آن را در قسمت بعد تعریف میکنیم، برای نمایش آیتمهای مورد نظر استفاده کردهایم. براي فعال شدن اين بخش بايد كلمه pass درخط 36 فهرست 1 با عبارت () ckb.Search جايگزين شود.
def Search(self):
print
print “=”*55
print “Searching in recipes by name”
term = raw_input(“Enter name of the recipe: “)
sql = “SELECT pkID , name FROM Recipes WHERE name like\ ‘%%%s%%’” %term
for x in cursor.execute(sql):
self.Show(x[0])
فهرست 4- كدهای تابع جستوجو در پايگاه داده براساس نام دستورالعمل
def Show(self,which):
sql = “SELECT * FROM Recipes WHERE pkID = %s” %str(which)
print “\n”
print “=”*55
for x in cursor.execute(sql):
print “Title: %s \t Serves: %s \t Source: %s”\ %(x[1],x[2],x[3])
sql = “SELECT * FROM Ingredients WHERE pkID = %s” %str(which)
print “\nIngredients:”
for x in cursor.execute(sql):
print x[1]
sql = “SELECT * FROM Instructions WHERE pkID = %s” %str(which)
print “\nInstructions:”
for x in cursor.execute(sql):
print x[1]
print “=”*55
print “\n”
فهرست 5- كدهای تابع مورد نياز برای نمايش يك آيتم از پايگاه داده
نمایش یک مورد
برای عملیاتی کردن این بخش، ابتدا با فراخوانی تابع ()All تمام موارد را به کاربر نشان خواهیم داد و از او خواهیم خواست که آیتم مورد نظر را انتخاب کند.براي اين كار كلمه pass در خط 38 فهرست 1 را با كدهای زير جايگزين كنيد:
ckb.All()
temp = raw_input(“What to show:”)
ckb.Show(temp)
پس از آن با فرستادن آیتم انتخاب شده به عنوان آرگومان which به روتین ()Show آن آیتم را به نمایش خواهیم گذاشت. کدهای مربوط به این روتین در فهرست 5 آورده شده است. اين كدها را جايگزين خطوط 11 و 12 فهرست 1 كنيد. در این کد، در خط 2 دستور sql مورد نیاز را برای انتخاب آیتمی که شماره ردیف (pkID) آن با آرگومان which به تابع اعلام شده است، تعریف کردهایم. پس از آن با تعریف دو دستور sql دیگر مقادیر متناظر را از جدولهای Ingredients و Instructions استخراج کرده و با دستور print چاپ کردهایم.
def Add(self):
ings = ““
lastid = 0
recipename=raw_input(‘Enter Recipe Title -> ‘)
recipesource=raw_input(“Enter Recipe Source -> “)
recipeserves=raw_input(“Enter number of servings -> “)
while True:
ing = raw_input(‘Enter Ingredient (“0” to exit) -> ‘)
if ing != ‘0’:
ings = ings + ing + “, “
else:
break
instructions = raw_input(‘Enter Instructions -> ‘)
print ‘=’*55
print “Here›s what we have so far”
print “Title: %s” % recipename
print “Source: %s” % recipesource
print “Serves: %s” % recipeserves
print “Ingredients: %s” % ings
print “Instructions: %s” % instructions
print ‘=’*55
resp = raw_input(“OK to save? (Y/n) -> “)
if resp.upper() != ‘N’:
#connection=apsw.Connection(“cookbook1.db3”)
#cursor=connection.cursor()
# Write the Recipe Record
sql = ‘INSERT INTO Recipes (name,serves,source) VALUES\ (“%s”,”%s”,”%s”)’ %(recipename,recipeserves,recipesource)
cursor.execute(sql)
# Get the new Recipe pkID
sql = “SELECT last_insert_rowid()”
cursor.execute(sql)
for x in cursor.execute(sql):
lastid = x[0]
print “last id = %s” % lastid
# Write the Instruction Record
sql = ‘INSERT INTO Ingredients (recipeID,ingredients)\ VALUES (%s,”%s”)’ % (lastid,x)
cursor.execute(sql)
# Write the Ingredients records
sql = ‘INSERT INTO Instructions (recipeID,instructions)\ VALUES( %s,»%s»)’ %(lastid,instructions)
cursor.execute(sql)
# Prompt the user that we are done
print ‘Done\n’
else:
print ‘Save aborted\n’
فهرست 6- كدهای تابع افزودن آيتم جديد به پايگاه داده
افزودن
روتین مربوط به افزودن موارد، طولانیترین روتین این مجموعه است که آن را در فهرست 6 مشاهده میکنید، آن را جايگزين خطوط 13 و14 فهرست 1 كنيد. شروع این روتین و خطهای 2 تا 6 متغیرهای ابتدایی مورد نیاز نظیر نام دستورالعمل، تعداد نفرات و... را تعریف و مقداردهی میکند. تنها موردی که شاید به توضیح نياز داشته باشد، دریافت مواد لازم است که در یک حلقه while انجام شده است و هر ورودی کاربر بهصورت رشتهای با جداکننده کاما (،) به انتهای متغیر ings افزوده شده است. این روند تا زمانی که کاربر0 را وارد کند، ادامه مییابد. پس از آن در خطوط 14 تا 21 کل اطلاعات یک بار دیگر برای کاربر نمایش داده میشود تا از صحت آن اطمینان حاصل شود.
پس از گرفتن تأیید کاربر، در خطوط 27 تا 29 با تعریف دستورالعمل مورد نیاز، موارد ابتدایی را در جدول Recipes ذخیره میکنیم. در خطوط 31 و 32 همانگونه که در قسمت قبل دیدهاید، شماره آخرین رکورد افزوده شده به جدول را استخراج کردهایم. از این رکورد برای مرتبط کردن دادههای جدولهاي Ingredients و Instructions به مقادیر وارد شده در جدول Recipes استفاده کردهایم. ذخیره داده در دو جدول Ingredients و Instructions به ترتیب در خطوط 36 تا 39 و40 تا 43 انجام شده است. در نهایت، اتمام عملیات ذخیرهسازی با یک پیغام به کاربر اطلاع داده شده است.فراموش نكنيدكه براي فعال شدن اين بخش بايد كلمه pass در خط 40 فهرست 1 را با ()ckb.Add جايگزين كنيد.
حذف
در نهایت به روتین حذف موارد میرسیم. همانگونه که حدس میزنید، در این روتین نیز ابتدا با فراخوانی()ckb.All همه موارد به کاربر نشان داده شده و در نهایت از او خواسته میشود تا آیتم مورد نظر را برای حذفکردن انتخاب کند. این روتین در فهرست 6 آورده شده است.آن را جايگزين خطوط 15 و 16 فهرست 1 كنيد و برای كار كردن اين كد بايد كلمه pass در خط42 فهرست1 با عبارت زير جايگزين شود:
ckb.All()
temp = raw_input(“What to delete:”)
ckb.Delete(temp)
در این کد هم با استفاده از آرگومان which که شماره انحصاری آیتم را نشان میدهد، دستورات sql مورد نیاز را برای حذف آیتمها از جدولهای Recipes، Ingredients و Instructions تعریف و اجرا کردهایم.دقت کنید که برای سادهترشدن کار، ما از بسیاری از روتینهای کنترل ورودی کاربر، مرتبسازی خروجی و بسیاری قابلیتهای دیگر که میتوانست چنین برنامهای را کاملترکند، صرفنظرکردهایم. اگرچه وجود این قابلیتها در غالب نرمافزارهای تجاری و حرفهای الزامی است، اما پیادهسازی آنها بسیار ساده و بدون مشکل خواهد بود. برای نمونه، در هنگام نمایش یا حذف یک مورد بهتر بود که ما شماره آیتم واردشده توسط کاربر را بررسی کنیم تا در محدوده صحیحی قرار داشته باشد یا مثلاً کاربر به جای شماره از حروف استفاده نکرده باشد. که چنين مواردی با روالهای معمول if قابل پیادهسازی است.
ماهنامه شبکه را از کجا تهیه کنیم؟
ماهنامه شبکه را میتوانید از کتابخانههای عمومی سراسر کشور و نیز از دکههای روزنامهفروشی تهیه نمائید.
ثبت اشتراک نسخه کاغذی ماهنامه شبکه
ثبت اشتراک نسخه آنلاین
کتاب الکترونیک +Network راهنمای شبکهها
- برای دانلود تنها کتاب کامل ترجمه فارسی +Network اینجا کلیک کنید.
کتاب الکترونیک دوره مقدماتی آموزش پایتون
- اگر قصد یادگیری برنامهنویسی را دارید ولی هیچ پیشزمینهای ندارید اینجا کلیک کنید.
نظر شما چیست؟