هناك العديد من خِدْمَات تحويل الصوت إلى كلام على اﻹنترنت، لكن القليل منها يدعم اللغة العربية بدقة عالية. ومن هذا القليل خدمة wit.ai التي تعرفت إليها حديثًا (وهي من تطوير فيس بوك للأسف) وتوفر العديد من اﻷمور المتعلقة بمعالجة اللغات الطبيعية ومن ضمنها تحويل الصوت إلى كلام مجانا مع دعم عدد كبير جدا من اللغات. وقد جربت اﻷداة في تفريغ الدروس العلمية ووجدت أن دِقَّة التفريغ جيدة جدا لذلك أنشأت أداة صغيرة لتفريغ الملفات الصوتية بالاعتماد على خدمة wit.ai.
اﻷدوات البديلة
هناك عدد من الأدوات الموجودة فعلًا التي إما تستخدم خدمة wit.ai مثل بوتات تليجرام TranscriberBot و voicy، أو تستخدم خِدْمَات جوجل وغيرها لتحويل الكلام إلى نص مثل pyTranscriber و autosub. لكن المشكلة في المجموعة اﻷولى هي كونها مرتبطة بتليجرام فقط، والثانية أنها لا تدعم خدمة wit التي تتعامل مع اللغة العربية بشكل جيد.
أداة Wit Transcriber
هي أداة سطر أوامر بسيطة تتعامل مع الواجهة البرمجية الخاصة بخدمة wit.ai وتحديدا الجزء الذي يوفر تحويل الكلام إلى نص. اﻷداة مكتوبة باستخدام Python3 ومكتبات httpx و pydub (لتحويل الملفات الصوتية باستخدام FFmpeg). تحول الأداة أي مِلَفّ صوت أو فيديو يحدده المستخدم إلى الصيغة الصوتية الملائمة للواجهة البرمجية الخاصة ب wit.ai ثم تقسم المِلَفّ إلى أجزاء صغيرة وأخيرا ترفعها إلى خدمة wit.ai وتستقبل التفريغ النصي ثم تجمعه في مِلَفّ واحد.
اﻷداة مفتوحة المصدر وموجودة هنا: https://github.com/yshalsager/wit_transcriber
إعداد Wit.ai
افتح wit.ai وسجل الدخول بحساب فيس بوك.
اضغط على New App لإنشاء تطبيق جديد.
اختر اسمًا للتطبيق واختر لغةَ ثم عدل إعدادات ظهور التطبيق إلى خاص واضغط إنشاء.
افتح قسم اﻹدارة ثم اﻹعدادات Management > Settings.
أسفل قسم Client Access Token section ستجد مفتاح استخدام الواجهة البرمجية، انسخه لتستخدمه في الخطوة التالية.
تحميل اﻷداة
يمكن لمن يستطيع التعامل مع بايثون نسخ مستودع الكود واستخدام اﻷداة. ولمن لا يستطيع ذلك يمكنه تحميل المِلَفّ التنفيذي الخاص باﻷداة سواء على نظام ويندوز أو لينكس.
ملاحظة: يجب تثبيت ffmpeg على لينكس لاستخدام اﻷداة، أما ويندوز فممكن تحميل الملفات التنفيذية من الرابط في الخطوة التالية.
- حمل مِلَفّ اﻷداة التنفيذي من هنا (ويندوز - لينكس) وضعه في مجلد جديد.
- حمل ملفات ffmpeg إذا كنت تستخدم ويندوز من هنا، ثم فك الضغط عنها وانسخ الملفات الموجودة في bin إلى نفس مكان مِلَفّ wit_transcriber)
إعداد الأداة
اﻵن يجب وضع مفتاح استخدام واجهة wit.ai الذي حصلنا عليه في الخطوة اﻷولى.
- في نفس مكان مِلَفّ wit_transcriber ننشيء مِلَفّ جديد اسمه
config.json
(وليسconfig.json.txt
) وننسخ بداخله التالي مع استبدال xxxxxxxx بClient Access Token الذي حصلنا عليه في الخطوة 1-5 ثم نحفظ المِلَفّ.
1{
2 "ar": "xxxxxxxxxxxxxx"
3}
- ويمكنك إضافة لغات أخرى بنفس الطريقة.
تشغيل واستخدام الأداة
نحن الآن داخل مجلد الأداة والذي به مِلَفّ wit_transcriber.
نضغط على شريط العنوان (1 بالصورة) ثم نكتب cmd كما هو موضح بصورة 2 ثم نضغط زر enter.
ننسخ المِلَفّ المراد تفريغه إلى نفس مجلد الأداة ونسميه باسم ليس به مسافات ولا حروف عربية.
بداخل شاشة موجه الأوامر نكتب التالي لتشغيل الأداة
wit_transcriber.exe -i filename.extension
مع استبدال كلمة filename باسم المِلَفّ المراد تفريغه مع صيغة الملف.
ملاحظة: الخطوات من 1-3 مطلوبة فقط أول مرة بعد ذلك لاستخدام الأداة في أي وقت تتبع الخطوات بداية من 4 (تشغيل واستخدام الأداة) فقط.
1usage: wit_transcriber.py [-h] -i INPUT [-o OUTPUT] [-c CONFIG] [-x CONNECTIONS] [-l LANG] [-v]
2
3options:
4 -h, --help show this help message and exit
5 -i INPUT, --input INPUT
6 Path of media file to be transcribed.
7 -o OUTPUT, --output OUTPUT
8 Path of output file.
9 -c CONFIG, --config CONFIG
10 Path of config file.
11 -x CONNECTIONS, --connections CONNECTIONS
12 Number of API connections limit.
13 -l LANG, --lang LANG Language to use.
14 -v, --verbose Print API responses.
مزيد من التحسينات
- تحتاج اﻷداة اﻵن إلى واجهة رسومية تجعل استخدامها سهلا لكل أنواع المستخدمين، ولعلي أعمل على ذلك قريبا إن تيسر إن شاء الله.
- يمكن استخدام أداة مدقق صخر لتصليح الأخطاء اللغوية الموجودة في التفريع النصي بشكل آلي وتوفير وقت وجهد كبيرين.
التعليقات