8.5 KiB
تنظیم یک تایمر - سختافزار مجازی IoT و رزبری پای
در این بخش از درس، شما کد بدون سرور خود را فراخوانی میکنید تا گفتار را درک کرده و بر اساس نتایج، یک تایمر روی دستگاه مجازی IoT یا رزبری پای تنظیم کنید.
تنظیم یک تایمر
متنی که از فراخوانی تبدیل گفتار به متن بازمیگردد، باید به کد بدون سرور شما ارسال شود تا توسط LUIS پردازش شود و تعداد ثانیههای تایمر را بازگرداند. این تعداد ثانیهها میتواند برای تنظیم تایمر استفاده شود.
تایمرها را میتوان با استفاده از کلاس threading.Timer
در پایتون تنظیم کرد. این کلاس یک زمان تأخیر و یک تابع میگیرد و پس از زمان تأخیر، تابع اجرا میشود.
وظیفه - ارسال متن به تابع بدون سرور
-
پروژه
smart-timer
را در VS Code باز کنید و مطمئن شوید که محیط مجازی در ترمینال بارگذاری شده است، اگر از یک دستگاه مجازی IoT استفاده میکنید. -
بالای تابع
process_text
، یک تابع به نامget_timer_time
تعریف کنید تا نقطه پایانی REST که ایجاد کردهاید را فراخوانی کند:def get_timer_time(text):
-
کد زیر را به این تابع اضافه کنید تا URL مورد نظر برای فراخوانی را تعریف کند:
url = '<URL>'
<URL>
را با URL نقطه پایانی REST که در درس قبلی ساختهاید جایگزین کنید، چه روی کامپیوتر شما باشد یا در فضای ابری. -
کد زیر را اضافه کنید تا متن بهعنوان یک ویژگی که بهصورت JSON ارسال میشود، تنظیم شود:
body = { 'text': text } response = requests.post(url, json=body)
-
در ادامه،
seconds
را از payload پاسخ بازیابی کنید و در صورت شکست فراخوانی، مقدار 0 را بازگردانید:if response.status_code != 200: return 0 payload = response.json() return payload['seconds']
فراخوانیهای HTTP موفق کد وضعیت در محدوده 200 بازمیگردانند و کد بدون سرور شما در صورتی که متن پردازش شده و بهعنوان نیت تنظیم تایمر شناسایی شود، کد 200 بازمیگرداند.
وظیفه - تنظیم تایمر در یک رشته پسزمینه
-
عبارت import زیر را در بالای فایل اضافه کنید تا کتابخانه threading پایتون را وارد کنید:
import threading
-
بالای تابع
process_text
، یک تابع برای گفتن پاسخ اضافه کنید. فعلاً این تابع فقط در کنسول مینویسد، اما بعداً در این درس متن را میخواند.def say(text): print(text)
-
در ادامه، یک تابع اضافه کنید که توسط تایمر فراخوانی میشود تا اعلام کند تایمر به پایان رسیده است:
def announce_timer(minutes, seconds): announcement = 'Times up on your ' if minutes > 0: announcement += f'{minutes} minute ' if seconds > 0: announcement += f'{seconds} second ' announcement += 'timer.' say(announcement)
این تابع تعداد دقیقهها و ثانیههای تایمر را میگیرد و یک جمله میسازد که اعلام میکند تایمر به پایان رسیده است. این تابع تعداد دقیقهها و ثانیهها را بررسی میکند و فقط هر واحد زمانی را که عددی دارد، شامل میشود. برای مثال، اگر تعداد دقیقهها 0 باشد، فقط ثانیهها در پیام گنجانده میشوند. این جمله سپس به تابع
say
ارسال میشود. -
در ادامه، تابع
create_timer
زیر را برای ایجاد تایمر اضافه کنید:def create_timer(total_seconds): minutes, seconds = divmod(total_seconds, 60) threading.Timer(total_seconds, announce_timer, args=[minutes, seconds]).start()
این تابع تعداد کل ثانیههای تایمر را که در فرمان ارسال میشود میگیرد و آن را به دقیقهها و ثانیهها تبدیل میکند. سپس یک شیء تایمر با استفاده از تعداد کل ثانیهها ایجاد و شروع میکند و تابع
announce_timer
و یک لیست شامل دقیقهها و ثانیهها را به آن ارسال میکند. وقتی تایمر به پایان میرسد، تابعannounce_timer
را فراخوانی میکند و محتوای این لیست را بهعنوان پارامترها ارسال میکند - بنابراین اولین آیتم لیست بهعنوان پارامترminutes
و دومین آیتم بهعنوان پارامترseconds
ارسال میشود. -
به انتهای تابع
create_timer
کدی اضافه کنید تا پیامی برای کاربر ساخته شود که اعلام کند تایمر در حال شروع است:announcement = '' if minutes > 0: announcement += f'{minutes} minute ' if seconds > 0: announcement += f'{seconds} second ' announcement += 'timer started.' say(announcement)
باز هم، این پیام فقط واحد زمانیای را که مقداری دارد شامل میشود. این جمله سپس به تابع
say
ارسال میشود. -
کد زیر را به انتهای تابع
process_text
اضافه کنید تا زمان تایمر را از متن دریافت کرده و سپس تایمر را ایجاد کند:seconds = get_timer_time(text) if seconds > 0: create_timer(seconds)
تایمر فقط در صورتی ایجاد میشود که تعداد ثانیهها بیشتر از 0 باشد.
-
برنامه را اجرا کنید و مطمئن شوید که برنامه تابع نیز در حال اجرا است. چند تایمر تنظیم کنید و خروجی نشان میدهد که تایمر تنظیم شده و سپس نشان میدهد که تایمر به پایان رسیده است:
pi@raspberrypi:~/smart-timer $ python3 app.py Set a two minute 27 second timer. 2 minute 27 second timer started. Times up on your 2 minute 27 second timer.
💁 میتوانید این کد را در پوشه code-timer/pi یا code-timer/virtual-iot-device پیدا کنید.
😀 برنامه تایمر شما موفقیتآمیز بود!
سلب مسئولیت:
این سند با استفاده از سرویس ترجمه هوش مصنوعی Co-op Translator ترجمه شده است. در حالی که ما تلاش میکنیم دقت را حفظ کنیم، لطفاً توجه داشته باشید که ترجمههای خودکار ممکن است شامل خطاها یا نادرستیها باشند. سند اصلی به زبان اصلی آن باید به عنوان منبع معتبر در نظر گرفته شود. برای اطلاعات حساس، توصیه میشود از ترجمه حرفهای انسانی استفاده کنید. ما مسئولیتی در قبال سوءتفاهمها یا تفسیرهای نادرست ناشی از استفاده از این ترجمه نداریم.