الفرق بين المراجعتين ل"Python/saving json"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
ط (استبدال النص - 'Python/defining-functions' ب'Python/defining_functions')
 
(4 مراجعات متوسطة بواسطة نفس المستخدم غير معروضة)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE:حفظ البيانات المهيكلة بصيغة json}}</noinclude>
+
<noinclude>{{DISPLAYTITLE:حفظ البيانات المهيكلة بصيغة JSON في بايثون}}</noinclude>
 
يمكن قراءة وكتابة [[Python/str|السلاسل النصية]] في الملفات بسهولة ويسر، أما الأرقام فتحتاج إلى المزيد من الجهد لأنّ التابع <code>read()‎</code> يعيد [[Python/str|السلاسل النصية]] فقط والتي يجب تمريرها إلى دالة مثل <code>int()</code>‎ والتي تأخذ [[Python/str|سلسلة نصية]] مثل <code>'123'</code> وتعيد القيمة العددية <code>123</code>. أما البيانات الأكثر تعقيدًا مثل [[Python/list|القوائم]] أو [[Python/dict|القواميس]] المتداخلة فتحتاج إلى عمليات تحليل (parsing) وسَلسَلة (serializing) لا يمكن القيام بها بصورة يدوية.
 
يمكن قراءة وكتابة [[Python/str|السلاسل النصية]] في الملفات بسهولة ويسر، أما الأرقام فتحتاج إلى المزيد من الجهد لأنّ التابع <code>read()‎</code> يعيد [[Python/str|السلاسل النصية]] فقط والتي يجب تمريرها إلى دالة مثل <code>int()</code>‎ والتي تأخذ [[Python/str|سلسلة نصية]] مثل <code>'123'</code> وتعيد القيمة العددية <code>123</code>. أما البيانات الأكثر تعقيدًا مثل [[Python/list|القوائم]] أو [[Python/dict|القواميس]] المتداخلة فتحتاج إلى عمليات تحليل (parsing) وسَلسَلة (serializing) لا يمكن القيام بها بصورة يدوية.
  
 
وبدلًا من إجبار المستخدمين على كتابة الشيفرات وتنقيحها بصورة مستمرة لغرض حفظ البيانات المعقّدة في الملفات، تتيح بايثون استخدام صيغة تبادل البيانات المعروفة JSON (اختصار JavaScript Object Notation).
 
وبدلًا من إجبار المستخدمين على كتابة الشيفرات وتنقيحها بصورة مستمرة لغرض حفظ البيانات المعقّدة في الملفات، تتيح بايثون استخدام صيغة تبادل البيانات المعروفة JSON (اختصار JavaScript Object Notation).
  
تحوّل الوحدة القياسية <code>json</code> أنواع البيانات في بايثون إلى [[Python/str|سلاسل نصية]] تمثّل تلك البيانات في عملية تدعى بالسَلسَلة، وتعيد هذه الوحدة بناء البيانات من [[Python/str|السلاسل النصية]] الممثّلة لها في عملية تدعى بإلغاء السلسلة (deserializing).
+
تحوّل الوحدة القياسية <code>[[Python/json|json]]</code> أنواع البيانات في بايثون إلى [[Python/str|سلاسل نصية]] تمثّل تلك البيانات في عملية تدعى بالسَلسَلة، وتعيد هذه الوحدة بناء البيانات من [[Python/str|السلاسل النصية]] الممثّلة لها في عملية تدعى بإلغاء السلسلة (deserializing).
  
 
وبين هاتين العمليتين يمكن للسِلسلة النصية التي تمثّل الكائن أن تخزّن على هيئة ملفّ أو بيانات أو تُرسل عبر الشبكة إلى حاسوب آخر.
 
وبين هاتين العمليتين يمكن للسِلسلة النصية التي تمثّل الكائن أن تخزّن على هيئة ملفّ أو بيانات أو تُرسل عبر الشبكة إلى حاسوب آخر.
سطر 16: سطر 16:
 
>>> json.dumps([1, 'simple', 'list'])
 
>>> json.dumps([1, 'simple', 'list'])
 
'[1, "simple", "list"]'
 
'[1, "simple", "list"]'
</syntaxhighlight>تقدّم بايثون [[Python/defining-functions|دالة]] أخرى مشابهة هي الدالة <code>dump()‎</code> والتي تقوم بسلسلة الكائن إلى ملف نصّي. إذا كان هناك كائن ملف نصي باسم <code>f</code> ومفتوح للكتابة فيمكن القيام بما يلي:<syntaxhighlight lang="python3">
+
</syntaxhighlight>تقدّم بايثون [[Python/defining_functions|دالة]] أخرى مشابهة هي الدالة <code>[[Python/json/dump|dump()‎]]</code> والتي تقوم بسلسلة الكائن إلى ملف نصّي. إذا كان هناك كائن ملف نصي باسم <code>f</code> ومفتوح للكتابة فيمكن القيام بما يلي:<syntaxhighlight lang="python3">
 
json.dump(x, f)
 
json.dump(x, f)
</syntaxhighlight>ويمكن استخدام الدالة  <code>load()‎</code> لفك ترميز الكائن من جديد، فإن كان كائن الملف النصي <code>f</code> مفتوحًا للقراءة مثلًا:<syntaxhighlight lang="python3">
+
</syntaxhighlight>ويمكن استخدام الدالة  <code>[[Python/json/load|load()‎]]</code> لفك ترميز الكائن من جديد، فإن كان كائن الملف النصي <code>f</code> مفتوحًا للقراءة مثلًا:<syntaxhighlight lang="python3">
 
x = json.load(f)
 
x = json.load(f)
 
</syntaxhighlight>يمكن لأسلوب السلسلة البسيط هذا أن يتعامل مع [[Python/list|القوائم]] و<nowiki/>[[Python/dict|القواميس]]، ولكن تحتاج عملية سلسلة [[Python/class|الأصناف]] إلى المزيد من الجهد.
 
</syntaxhighlight>يمكن لأسلوب السلسلة البسيط هذا أن يتعامل مع [[Python/list|القوائم]] و<nowiki/>[[Python/dict|القواميس]]، ولكن تحتاج عملية سلسلة [[Python/class|الأصناف]] إلى المزيد من الجهد.

المراجعة الحالية بتاريخ 14:30، 29 مايو 2018

يمكن قراءة وكتابة السلاسل النصية في الملفات بسهولة ويسر، أما الأرقام فتحتاج إلى المزيد من الجهد لأنّ التابع read()‎ يعيد السلاسل النصية فقط والتي يجب تمريرها إلى دالة مثل int()‎ والتي تأخذ سلسلة نصية مثل '123' وتعيد القيمة العددية 123. أما البيانات الأكثر تعقيدًا مثل القوائم أو القواميس المتداخلة فتحتاج إلى عمليات تحليل (parsing) وسَلسَلة (serializing) لا يمكن القيام بها بصورة يدوية.

وبدلًا من إجبار المستخدمين على كتابة الشيفرات وتنقيحها بصورة مستمرة لغرض حفظ البيانات المعقّدة في الملفات، تتيح بايثون استخدام صيغة تبادل البيانات المعروفة JSON (اختصار JavaScript Object Notation).

تحوّل الوحدة القياسية json أنواع البيانات في بايثون إلى سلاسل نصية تمثّل تلك البيانات في عملية تدعى بالسَلسَلة، وتعيد هذه الوحدة بناء البيانات من السلاسل النصية الممثّلة لها في عملية تدعى بإلغاء السلسلة (deserializing).

وبين هاتين العمليتين يمكن للسِلسلة النصية التي تمثّل الكائن أن تخزّن على هيئة ملفّ أو بيانات أو تُرسل عبر الشبكة إلى حاسوب آخر.

ملاحظة:

يشيع استخدام نسق JSON في التطبيقات الحديثة لغرض تبادل البيانات، وهي معروفة بين أوساط المبرمجين؛ لذا تعد JSON الخيار الأمثل لتبادل البيانات.

يمكن مشاهدة السلسلة النصية الممثّلة لأي كائن باستخدام الشيفرة التالية:

>>> import json
>>> json.dumps([1, 'simple', 'list'])
'[1, "simple", "list"]'

تقدّم بايثون دالة أخرى مشابهة هي الدالة dump()‎ والتي تقوم بسلسلة الكائن إلى ملف نصّي. إذا كان هناك كائن ملف نصي باسم f ومفتوح للكتابة فيمكن القيام بما يلي:

json.dump(x, f)

ويمكن استخدام الدالة load()‎ لفك ترميز الكائن من جديد، فإن كان كائن الملف النصي f مفتوحًا للقراءة مثلًا:

x = json.load(f)

يمكن لأسلوب السلسلة البسيط هذا أن يتعامل مع القوائم والقواميس، ولكن تحتاج عملية سلسلة الأصناف إلى المزيد من الجهد.

يمكن مراجعة توثيق الوحدة json للمزيد من التفاصيل.

مصادر