الفرق بين المراجعتين ل"Python/pathlib/Path"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
سطر 51: سطر 51:
  
 
</syntaxhighlight><span> </span>
 
</syntaxhighlight><span> </span>
===نكهات المسارات الصلبة===
+
==نكهات المسارات الصلبة==
 
يمكن إنشاء كائن من الصنف <code>Path</code> بثلاث طرق مختلفة:
 
يمكن إنشاء كائن من الصنف <code>Path</code> بثلاث طرق مختلفة:
  
سطر 93: سطر 93:
 
NotImplementedError: cannot instantiate 'WindowsPath' on your system
 
NotImplementedError: cannot instantiate 'WindowsPath' on your system
 
</syntaxhighlight>
 
</syntaxhighlight>
===توابع الصنف <code>Path</code>===
+
==توابع الصنف <code>Path</code>==
 
يتيح الصنف <code>Path</code> استخدام جميع التوابع الخاصة بالصنف <code>PurePath</code> وذلك لأنه يرث منه، ويضيف عليها التوابع التالية، التي تسمح بالقيام باستدعاءات النظام (system calls)، وترمي هذه التوابع استثناء <code>OSError</code> في حال فشل أيٍّ منها (كأن يكون المسار الذي يتم التعامل معه غير موجود مثلًا).
 
يتيح الصنف <code>Path</code> استخدام جميع التوابع الخاصة بالصنف <code>PurePath</code> وذلك لأنه يرث منه، ويضيف عليها التوابع التالية، التي تسمح بالقيام باستدعاءات النظام (system calls)، وترمي هذه التوابع استثناء <code>OSError</code> في حال فشل أيٍّ منها (كأن يكون المسار الذي يتم التعامل معه غير موجود مثلًا).
====التابع <code>Path.cwd</code>====
+
===التابع <code>Path.cwd</code>===
 
يعيد كائن مسار جديدًا يمثّل المسار الحالي (بشكل مشابه للتابع os.getcwd)<syntaxhighlight lang="python3">
 
يعيد كائن مسار جديدًا يمثّل المسار الحالي (بشكل مشابه للتابع os.getcwd)<syntaxhighlight lang="python3">
 
>>> Path.cwd()
 
>>> Path.cwd()
 
PosixPath('/home/antoine/pathlib')
 
PosixPath('/home/antoine/pathlib')
 
</syntaxhighlight>
 
</syntaxhighlight>
====التابع <code>Path.home</code>====
+
===التابع <code>Path.home</code>===
 
يعيد كائن مسار جديدًا يمثّل المسار الرئيسي (home directory) للمستخدم (بشكل مشابه للتابع os.path.expanduser مع الوسيط <code>'~'</code>)
 
يعيد كائن مسار جديدًا يمثّل المسار الرئيسي (home directory) للمستخدم (بشكل مشابه للتابع os.path.expanduser مع الوسيط <code>'~'</code>)
  
سطر 107: سطر 107:
 
PosixPath('/home/mostafa')
 
PosixPath('/home/mostafa')
 
</syntaxhighlight>
 
</syntaxhighlight>
====التابع <code>Path.stat</code>====
+
===التابع <code>Path.stat</code>===
 
يعيد معلومات عن المسار (مماثل للتابع <code>os.stat</code>) ، ويتم حساب المعلومات في كل مرة يتم فيها استدعاء التابع<syntaxhighlight lang="python3">
 
يعيد معلومات عن المسار (مماثل للتابع <code>os.stat</code>) ، ويتم حساب المعلومات في كل مرة يتم فيها استدعاء التابع<syntaxhighlight lang="python3">
 
>>> p = Path('setup.py')
 
>>> p = Path('setup.py')
سطر 117: سطر 117:
 
1327883547.852554
 
1327883547.852554
 
</syntaxhighlight>
 
</syntaxhighlight>
====التابع <code>Path.chmod</code>====
+
===التابع <code>Path.chmod</code>===
 
يقوم هذا التابع بتغيير نمط الملف وصلاحياته (مماثل للتابع <code>os.chmod</code>)<syntaxhighlight lang="python3">
 
يقوم هذا التابع بتغيير نمط الملف وصلاحياته (مماثل للتابع <code>os.chmod</code>)<syntaxhighlight lang="python3">
 
>>> p = Path('setup.py')
 
>>> p = Path('setup.py')
سطر 129: سطر 129:
 
33060
 
33060
 
</syntaxhighlight>
 
</syntaxhighlight>
====التابع <code>Path.exists</code>====
+
===التابع <code>Path.exists</code>===
 
يدلّ على كون المسار مشيرًا إلى ملف أو مجلد حقيقي أم لا<syntaxhighlight lang="python3">
 
يدلّ على كون المسار مشيرًا إلى ملف أو مجلد حقيقي أم لا<syntaxhighlight lang="python3">
 
>>> Path('.').exists()
 
>>> Path('.').exists()
سطر 145: سطر 145:
 
</syntaxhighlight>
 
</syntaxhighlight>
 
ملاحظة: إذا كان المسار يشير إلى اختصار (symlink) فإن استدعاء التابع <code>exists</code> يدل على ما يشير إليه الاختصار.
 
ملاحظة: إذا كان المسار يشير إلى اختصار (symlink) فإن استدعاء التابع <code>exists</code> يدل على ما يشير إليه الاختصار.
====التابع <code>Path.expanduser</code>====
+
===التابع <code>Path.expanduser</code>===
 
يعيد كائن مسار جديد يمدد فيه المسار الرئيسي للمستخدم الممثل بالرمز <code>'~'</code>، مشابه للتابع <code>os.path.expanduser</code><syntaxhighlight lang="python3">
 
يعيد كائن مسار جديد يمدد فيه المسار الرئيسي للمستخدم الممثل بالرمز <code>'~'</code>، مشابه للتابع <code>os.path.expanduser</code><syntaxhighlight lang="python3">
 
>>> p = PosixPath('~/films/Monty Python')
 
>>> p = PosixPath('~/films/Monty Python')
سطر 153: سطر 153:
  
 
</syntaxhighlight>New in version 3.5.
 
</syntaxhighlight>New in version 3.5.
====التابع <code>Path.glob</code>====
+
===التابع <code>Path.glob</code>===
 
تعيد جميع الملفات التي تحقق نمط [[wikipedia:Glob_(programming)|glob]] المعطى، مهما كان نوع الملف<syntaxhighlight lang="python3">
 
تعيد جميع الملفات التي تحقق نمط [[wikipedia:Glob_(programming)|glob]] المعطى، مهما كان نوع الملف<syntaxhighlight lang="python3">
 
>>> sorted(Path('.').glob('*.py'))
 
>>> sorted(Path('.').glob('*.py'))
سطر 169: سطر 169:
 
PosixPath('test_pathlib.py')]
 
PosixPath('test_pathlib.py')]
 
</syntaxhighlight>ملاحظة: احذر من استخدام النمط <code>"**"</code> في أشجار المجلدات الكبيرة، فإن ذلك قد يستهلك كمية هائلة من الوقت,
 
</syntaxhighlight>ملاحظة: احذر من استخدام النمط <code>"**"</code> في أشجار المجلدات الكبيرة، فإن ذلك قد يستهلك كمية هائلة من الوقت,
====التابع <code>Path.group</code>====
+
===التابع <code>Path.group</code>===
 
يعيد هذا التابع اسم المجموعة التي ينتمي لها الملف، ويرمي بالخطأ <code>KeyError</code>  إذا كان معرف المجموعة <code>gid</code> الخاص بالملف غير موجود في قاعدة بيانات النظام.
 
يعيد هذا التابع اسم المجموعة التي ينتمي لها الملف، ويرمي بالخطأ <code>KeyError</code>  إذا كان معرف المجموعة <code>gid</code> الخاص بالملف غير موجود في قاعدة بيانات النظام.
====التابع <code>Path.is_dir</code>====
+
===التابع <code>Path.is_dir</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى مجلد (أو إلى اختصار يشير إلى مجلد)، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى مجلد (أو إلى اختصار يشير إلى مجلد)، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
 
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
 
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
====التابع <code>Path.is_file</code>====
+
===التابع <code>Path.is_file</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى ملف نظامي(أو إلى اختصار يشير إلى ملف نظامي)، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى ملف نظامي(أو إلى اختصار يشير إلى ملف نظامي)، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
 
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
 
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
  
التابع <code>Path.is_mount</code>
+
=== التابع <code>Path.is_mount</code> ===
 
 
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار هو نقطة تثبيت [https://unix.stackexchange.com/questions/3247/understanding-mount-as-a-concept-in-the-os (mount point)] .
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار هو نقطة تثبيت [https://unix.stackexchange.com/questions/3247/understanding-mount-as-a-concept-in-the-os (mount point)] .
====التابع <code>Path.is_symlink</code>====
+
===التابع <code>Path.is_symlink</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى رابط دلالي (symbolic link)، و<code>False</code> فيما عدا ذلك.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى رابط دلالي (symbolic link)، و<code>False</code> فيما عدا ذلك.
  
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
====التابع <code>Path.is_socket</code>====
+
===التابع <code>Path.is_socket</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [[wikipedia:Unix_domain_socket|Unix socket]] (أو إلى اختصار يشير إلى<nowiki/>[[wikipedia:Unix_domain_socket|Unix socket]])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [[wikipedia:Unix_domain_socket|Unix socket]] (أو إلى اختصار يشير إلى<nowiki/>[[wikipedia:Unix_domain_socket|Unix socket]])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
====التابع <code>Path.is_fifo</code>====
+
===التابع <code>Path.is_fifo</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [[wikipedia:Named_pipe|FIFO]] (أو إلى اختصار يشير إلى [[wikipedia:Named_pipe|FIFO]])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [[wikipedia:Named_pipe|FIFO]] (أو إلى اختصار يشير إلى [[wikipedia:Named_pipe|FIFO]])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
====التابع <code>Path.is_block_device</code>====
+
===التابع <code>Path.is_block_device</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [https://unix.stackexchange.com/questions/259193/what-is-a-block-device block device] (أو إلى اختصار يشير إلى [https://unix.stackexchange.com/questions/259193/what-is-a-block-device block device])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [https://unix.stackexchange.com/questions/259193/what-is-a-block-device block device] (أو إلى اختصار يشير إلى [https://unix.stackexchange.com/questions/259193/what-is-a-block-device block device])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
 
كما أنه يعيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
====التابع <code>Path.is_char_device</code>====
+
===التابع <code>Path.is_char_device</code>===
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [https://arstechnica.com/civis/viewtopic.php?t=787631 character device] (أو إلى اختصار يشير إلى [https://arstechnica.com/civis/viewtopic.php?t=787631 character device])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
 
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [https://arstechnica.com/civis/viewtopic.php?t=787631 character device] (أو إلى اختصار يشير إلى [https://arstechnica.com/civis/viewtopic.php?t=787631 character device])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
====التابع <code>Path.iterdir</code>====
+
===التابع <code>Path.iterdir</code>===
 
يُسمح باستخدام هذا التابع على كائنات المسارات التي تشير إلى مجلدات، حيث يُنتج كائنات مسارات لكل محتويات المجلد، وتكون النتيجة قابلة للتكرار.
 
يُسمح باستخدام هذا التابع على كائنات المسارات التي تشير إلى مجلدات، حيث يُنتج كائنات مسارات لكل محتويات المجلد، وتكون النتيجة قابلة للتكرار.
  
سطر 218: سطر 217:
 
</syntaxhighlight>
 
</syntaxhighlight>
  
====التابع <code>Path.lchmod</code>====
+
===التابع <code>Path.lchmod</code>===
 
مشابه للتابع <code>Path.chmod</code>، ولكن عندما يشير المسار إلى اختصار، فإن هذا التابع يقوم بتغيير نمط الاختصار بدلًا من تغيير نمط الملف الذي يشير إليه الاختصار.
 
مشابه للتابع <code>Path.chmod</code>، ولكن عندما يشير المسار إلى اختصار، فإن هذا التابع يقوم بتغيير نمط الاختصار بدلًا من تغيير نمط الملف الذي يشير إليه الاختصار.
====التابع <code>Path.lstat</code>====
+
===التابع <code>Path.lstat</code>===
 
مشابه للتابع <code>Path.stat</code> ، ولكن عندما يشير المسار إلى اختصار، فإن هذا التابع يقوم بإعادة المعلومات المتعلقة بالاختصار ذاته بدلًا من إعادة المعلومات المرتبطة بالملف الذي يشير إليه الاختصار.
 
مشابه للتابع <code>Path.stat</code> ، ولكن عندما يشير المسار إلى اختصار، فإن هذا التابع يقوم بإعادة المعلومات المتعلقة بالاختصار ذاته بدلًا من إعادة المعلومات المرتبطة بالملف الذي يشير إليه الاختصار.
  
====التابع <code>[[Python/pathlib/Path/mkdir|Path.mkdir]]</code>====
+
===التابع <code>[[Python/pathlib/Path/mkdir|Path.mkdir]]</code>===
 
يُنشئ هذا التابع مجلّدًا في المسار المُعطى بالخصائص التي يتم تحديدها في باقي الوسطاء.  
 
يُنشئ هذا التابع مجلّدًا في المسار المُعطى بالخصائص التي يتم تحديدها في باقي الوسطاء.  
====التابع <code>Path.open</code>====
+
===التابع <code>Path.open</code>===
 
يفتح الملف الذي يشير إليه المسار، بطريقة مشابهة للتابع المضمن <code>open</code>
 
يفتح الملف الذي يشير إليه المسار، بطريقة مشابهة للتابع المضمن <code>open</code>
  
سطر 237: سطر 236:
 
</syntaxhighlight>
 
</syntaxhighlight>
  
====التابع <code>Path.owner</code>====
+
===التابع <code>Path.owner</code>===
 
يعيد هذا التابع اسم المستخدم المالك للملف. ويرمي استثناءً <code>KeyError</code>  إن كان معرف المستخدم <code>uid</code> غير موجود في قاعدة بيانات النظام.
 
يعيد هذا التابع اسم المستخدم المالك للملف. ويرمي استثناءً <code>KeyError</code>  إن كان معرف المستخدم <code>uid</code> غير موجود في قاعدة بيانات النظام.
====التابع <code>Path.read_bytes</code>====
+
===التابع <code>Path.read_bytes</code>===
 
يعيد هذا التابع المحتوى المرمّز للملف المُشار إليه ككائن من النوع <code>bytes</code>
 
يعيد هذا التابع المحتوى المرمّز للملف المُشار إليه ككائن من النوع <code>bytes</code>
  
سطر 253: سطر 252:
  
 
تم استحداث هذا التابع في النسخة 3.5
 
تم استحداث هذا التابع في النسخة 3.5
====التابع <code>Path.read_text</code>====
+
===التابع <code>Path.read_text</code>===
 
يعيد هذا التابع المحتوى النصي للملف كسلسلة نصية
 
يعيد هذا التابع المحتوى النصي للملف كسلسلة نصية
  
سطر 269: سطر 268:
  
 
تم استحداث هذا التابع في النسخة 3.5
 
تم استحداث هذا التابع في النسخة 3.5
====التابع <code>Path.rename</code>====
+
===التابع <code>Path.rename</code>===
 
يعيد تسمية الملف أو المجلد بما يحدده الوسيط المُعطى. في نظام يونكس، إذا كان اسم الملف بعد إعادة التسمية موجودًا فعلًا كملف، فإنه يُستبدل دون أي إنذار إذا لدى المستخدم الصلاحيات اللازمة لذلك.
 
يعيد تسمية الملف أو المجلد بما يحدده الوسيط المُعطى. في نظام يونكس، إذا كان اسم الملف بعد إعادة التسمية موجودًا فعلًا كملف، فإنه يُستبدل دون أي إنذار إذا لدى المستخدم الصلاحيات اللازمة لذلك.
  
سطر 288: سطر 287:
 
</syntaxhighlight>
 
</syntaxhighlight>
  
====التابع <code>Path.replace</code>====
+
===التابع <code>Path.replace</code>===
 
يستبدل الملف الحالي بملف الوجهة، حيث يقوم بإعادة التسمية إن لم تكن الوجهة موجودة، ويقوم بالاستبدال دون أي شرط في حال كانت الوجهة موجودة من قبل.
 
يستبدل الملف الحالي بملف الوجهة، حيث يقوم بإعادة التسمية إن لم تكن الوجهة موجودة، ويقوم بالاستبدال دون أي شرط في حال كانت الوجهة موجودة من قبل.
====التابع <code>[[Python/pathlib/Path/resolve|Path.resolve]]</code>====
+
===التابع <code>[[Python/pathlib/Path/resolve|Path.resolve]]</code>===
 
يجعل المسار مسارًا مطلقًا.
 
يجعل المسار مسارًا مطلقًا.
====التابع <code>Path.rglob</code>====
+
===التابع <code>Path.rglob</code>===
 
مشابه لاستدعاء التابع <code>glob</code> عند إضافة <code>'**'</code> في بداية النمط المُعطى
 
مشابه لاستدعاء التابع <code>glob</code> عند إضافة <code>'**'</code> في بداية النمط المُعطى
  
سطر 304: سطر 303:
 
</syntaxhighlight>
 
</syntaxhighlight>
  
التابع <code>[[Python/pathlib/Path/rmdir|Path.rmdir]]</code>
+
=== التابع <code>[[Python/pathlib/Path/rmdir|Path.rmdir]]</code> ===
 
 
 
يحذف المجلد إن كان خاليًا من الملفات.
 
يحذف المجلد إن كان خاليًا من الملفات.
====التابع <code>[[Python/pathlib/Path/samefile|Path.samefile]]</code>====
+
===التابع <code>[[Python/pathlib/Path/samefile|Path.samefile]]</code>===
 
يحدد فيما إذا كان المسار المعطى هو مطابقًا للمسار الخاص بالكائن.
 
يحدد فيما إذا كان المسار المعطى هو مطابقًا للمسار الخاص بالكائن.
  
التابع <code>[[Python/pathlib/Path/symlink to|Path.symlink_to]]</code>
+
=== التابع <code>[[Python/pathlib/Path/symlink to|Path.symlink_to]]</code> ===
 
 
 
يجعل من الكائن اختصارًا للملف المُعطى.
 
يجعل من الكائن اختصارًا للملف المُعطى.
====التابع <code>[[Python/pathlib/Path/touch|Path.touch]]</code>====
+
===التابع <code>[[Python/pathlib/Path/touch|Path.touch]]</code>===
 
يُنشئ ملفًّا في المسار المُعطى.
 
يُنشئ ملفًّا في المسار المُعطى.
====التابع <code>Path.unlink</code>====
+
===التابع <code>Path.unlink</code>===
 
يحذف الملف أو الاختصار الذي يشير إليه الكائن، أما إذا كان المسار يشير إلى مجلد فيجب استخدام التابع <code>Path.rmdir</code> بدلًا من هذا التابع.
 
يحذف الملف أو الاختصار الذي يشير إليه الكائن، أما إذا كان المسار يشير إلى مجلد فيجب استخدام التابع <code>Path.rmdir</code> بدلًا من هذا التابع.
====التابع <code>Path.write_bytes</code>====
+
===التابع <code>Path.write_bytes</code>===
 
يفتح الملف المُشار إليه في نمط <code>bytes</code>، ويكتب البيانات فيه ثم يُغلقه.
 
يفتح الملف المُشار إليه في نمط <code>bytes</code>، ويكتب البيانات فيه ثم يُغلقه.
  
سطر 333: سطر 330:
  
 
تابع مُستحدث في السخة 3.5.
 
تابع مُستحدث في السخة 3.5.
====التابع <code>Path.write_text</code>====
+
===التابع <code>Path.write_text</code>===
 
يفتح الملف المٌشار إليه بالنمط النصي، ويكتب البيانات فيه ثم يُغلقه.
 
يفتح الملف المٌشار إليه بالنمط النصي، ويكتب البيانات فيه ثم يُغلقه.
  
سطر 355: سطر 352:
 
للقيام بمعالجة منخفضة المستوى للمسارات على السلاسل النصية، يمكنك أيضًا استخدام الوحدة os.path
 
للقيام بمعالجة منخفضة المستوى للمسارات على السلاسل النصية، يمكنك أيضًا استخدام الوحدة os.path
 
|}
 
|}
===التقابل مع الوحدة os===
+
==التقابل مع الوحدة <code>os</code>==
 
يبيّن الجدول التالي تقابل عدة توابع من الوحدة <code>os</code>  مع ما يقابلها و يكافئها من الوحدة  <code>Path</code>.
 
يبيّن الجدول التالي تقابل عدة توابع من الوحدة <code>os</code>  مع ما يقابلها و يكافئها من الوحدة  <code>Path</code>.
 
{| class="wikitable"
 
{| class="wikitable"

مراجعة 12:32، 3 أغسطس 2018

الصنف pathlib.Path في بايثون

هو الصنف العام للأصناف التي تتعامل مع المسارات مع السماح بالقيام بعمليات الإدخال والإخراج، وتُسمّى بأصناف المسارات الصلبة Concrete Paths، نورد فيما يلي طريقة الاستخدام الأساسية:

استيراد الصنف الأساسي من الوحدة pathlib:

>>> from pathlib import Path #استيراد الصنف الأساسي

إنشاء كائن والتكرار على المجلدات والملفات التي بداخله:

>>> p = Path('.') #إنشاء كائن باستخدام باين الصنف العام

>>> [x for x in p.iterdir() if x.is_dir()] #تعداد المجلدات الموجودة ضمن المسار الحالي 
[PosixPath('.hg'), PosixPath('docs'), PosixPath('dist'),
PosixPath('__pycache__'), PosixPath('build')]

تعداد ملفات بايثون المصدرية في شجر ة المجلدات هذه:

>>> list(p.glob('**/*.py'))

[PosixPath('test_pathlib.py'), PosixPath('setup.py'),
PosixPath('pathlib.py'), PosixPath('docs/conf.py'),
PosixPath('build/lib/pathlib.py')]

التنقّل ضمن شجرة المجلدات، يظهر فيه استخدام عملية القسمة / المُعاد تعريفها لتقوم بالتنقل بين المجلدات:

>>> p = Path('/etc')
>>> q = p / 'init.d' / 'reboot'
>>> q

PosixPath('/etc/init.d/reboot')
>>> q.resolve()

PosixPath('/etc/rc.d/init.d/halt')

الاستعلام عن خصائص المسار:

>>> q.exists()

True

>>> q.is_dir()

False

فتح ملف:

>>> with q.open() as f: f.readline()

السطر الأول وأهلا بك
السطر الأخير وداعا

نكهات المسارات الصلبة

يمكن إنشاء كائن من الصنف Path بثلاث طرق مختلفة:

1- باستخدام باني الصنف العام Path، وتعتمد هذه الطريقة على إنشاء كائن من الصنف PosixPath أو WindowsPath حسب نظام التشغيل الذي يتم تفسير الشيفرة عليه:

>>> Path('setup.py')

PosixPath('setup.py')

2- باستخدام باني الصنف الخاص بالأنظمة المغايرة لويندوز PosixPath

>>> PosixPath('/etc')

PosixPath('/etc')

3- باستخدام باني الصنف الخاص بنظام ويندوز WindowsPath

>>> WindowsPath('c:/Program Files/')

WindowsPath('c:/Program Files')

إلا أنه يجب الانتباه إلى عدم القيام بأي استدعاءات للنظام عندما ننشئ كائنًا من أحد الصنفين الفرعيين السابقين على نظام تشغيل مغاير له، كما يوضح المثال التالي

>>>

>>> import os

>>> os.name
'posix'     #نظام التشغيل الذي يتم تفسير الشيفرة عليه مغاير لويندوز

>>> Path('setup.py')
PosixPath('setup.py')

>>> PosixPath('setup.py')
PosixPath('setup.py')

>>> WindowsPath('setup.py')  #لا تسمح أصناف المسارات الصلبة بإنشاء كائن مغاير لنوع النظام الذي يتم العمل عليه
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
 File "pathlib.py", line 798, in __new__
   % (cls.__name__,))
NotImplementedError: cannot instantiate 'WindowsPath' on your system

توابع الصنف Path

يتيح الصنف Path استخدام جميع التوابع الخاصة بالصنف PurePath وذلك لأنه يرث منه، ويضيف عليها التوابع التالية، التي تسمح بالقيام باستدعاءات النظام (system calls)، وترمي هذه التوابع استثناء OSError في حال فشل أيٍّ منها (كأن يكون المسار الذي يتم التعامل معه غير موجود مثلًا).

التابع Path.cwd

يعيد كائن مسار جديدًا يمثّل المسار الحالي (بشكل مشابه للتابع os.getcwd)

>>> Path.cwd()
PosixPath('/home/antoine/pathlib')

التابع Path.home

يعيد كائن مسار جديدًا يمثّل المسار الرئيسي (home directory) للمستخدم (بشكل مشابه للتابع os.path.expanduser مع الوسيط '~')

وهو تابع جديد في النسخة 3.5

>>> Path.home()
PosixPath('/home/mostafa')

التابع Path.stat

يعيد معلومات عن المسار (مماثل للتابع os.stat) ، ويتم حساب المعلومات في كل مرة يتم فيها استدعاء التابع

>>> p = Path('setup.py')

>>> p.stat().st_size
956

>>> p.stat().st_mtime
1327883547.852554

التابع Path.chmod

يقوم هذا التابع بتغيير نمط الملف وصلاحياته (مماثل للتابع os.chmod)

>>> p = Path('setup.py')

>>> p.stat().st_mode
33277

>>> p.chmod(0o444)

>>> p.stat().st_mode
33060

التابع Path.exists

يدلّ على كون المسار مشيرًا إلى ملف أو مجلد حقيقي أم لا

>>> Path('.').exists()
True

>>> Path('setup.py').exists()
True

>>> Path('/etc').exists()
True

>>> Path('nonexistentfile').exists()
False

ملاحظة: إذا كان المسار يشير إلى اختصار (symlink) فإن استدعاء التابع exists يدل على ما يشير إليه الاختصار.

التابع Path.expanduser

يعيد كائن مسار جديد يمدد فيه المسار الرئيسي للمستخدم الممثل بالرمز '~'، مشابه للتابع os.path.expanduser

>>> p = PosixPath('~/films/Monty Python')

>>> p.expanduser()
PosixPath('/home/eric/films/Monty Python')

New in version 3.5.

التابع Path.glob

تعيد جميع الملفات التي تحقق نمط glob المعطى، مهما كان نوع الملف

>>> sorted(Path('.').glob('*.py'))
[PosixPath('pathlib.py'), PosixPath('setup.py'), PosixPath('test_pathlib.py')]

>>> sorted(Path('.').glob('*/*.py'))
[PosixPath('docs/conf.py')]

يعني النمط "**" تحديد المجلد الحالي وجميه المجلدات الفرعية في داخله بشكل عودي (recursively)، وهو ما يسمّى recursive globbing

>>> sorted(Path('.').glob('**/*.py'))
[PosixPath('build/lib/pathlib.py'),
PosixPath('docs/conf.py'),
PosixPath('pathlib.py'),
PosixPath('setup.py'),
PosixPath('test_pathlib.py')]

ملاحظة: احذر من استخدام النمط "**" في أشجار المجلدات الكبيرة، فإن ذلك قد يستهلك كمية هائلة من الوقت,

التابع Path.group

يعيد هذا التابع اسم المجموعة التي ينتمي لها الملف، ويرمي بالخطأ KeyError إذا كان معرف المجموعة gid الخاص بالملف غير موجود في قاعدة بيانات النظام.

التابع Path.is_dir

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى مجلد (أو إلى اختصار يشير إلى مجلد)، بينما يعيد False في حال كان المسار يشير إلى أي نوع آخر من الملفات.

كما أنه عيد False إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.

التابع Path.is_file

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى ملف نظامي(أو إلى اختصار يشير إلى ملف نظامي)، بينما يعيد False في حال كان المسار يشير إلى أي نوع آخر من الملفات.

كما أنه عيد False إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.

التابع Path.is_mount

يعيد هذا التابع القيمة المنطقية True إذا كان المسار هو نقطة تثبيت (mount point) .

التابع Path.is_symlink

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى رابط دلالي (symbolic link)، وFalse فيما عدا ذلك.

كما أنه يعيد False إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.

التابع Path.is_socket

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى Unix socket (أو إلى اختصار يشير إلىUnix socket)، بينما يعيد False في حال كان المسار يشير إلى أي نوع آخر من الملفات.

كما أنه يعيد False إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.

التابع Path.is_fifo

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى FIFO (أو إلى اختصار يشير إلى FIFO)، بينما يعيد False في حال كان المسار يشير إلى أي نوع آخر من الملفات.

كما أنه يعيد False إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.

التابع Path.is_block_device

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى block device (أو إلى اختصار يشير إلى block device)، بينما يعيد False في حال كان المسار يشير إلى أي نوع آخر من الملفات.

كما أنه يعيد False إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.

التابع Path.is_char_device

يعيد هذا التابع القيمة المنطقية True إذا كان المسار يشير إلى character device (أو إلى اختصار يشير إلى character device)، بينما يعيد False في حال كان المسار يشير إلى أي نوع آخر من الملفات.

التابع Path.iterdir

يُسمح باستخدام هذا التابع على كائنات المسارات التي تشير إلى مجلدات، حيث يُنتج كائنات مسارات لكل محتويات المجلد، وتكون النتيجة قابلة للتكرار.

>>> p = Path('docs')

>>> for child in p.iterdir(): child
...
PosixPath('docs/conf.py')
PosixPath('docs/_templates')
PosixPath('docs/make.bat')
PosixPath('docs/index.rst')
PosixPath('docs/_build')
PosixPath('docs/_static')
PosixPath('docs/Makefile')

التابع Path.lchmod

مشابه للتابع Path.chmod، ولكن عندما يشير المسار إلى اختصار، فإن هذا التابع يقوم بتغيير نمط الاختصار بدلًا من تغيير نمط الملف الذي يشير إليه الاختصار.

التابع Path.lstat

مشابه للتابع Path.stat ، ولكن عندما يشير المسار إلى اختصار، فإن هذا التابع يقوم بإعادة المعلومات المتعلقة بالاختصار ذاته بدلًا من إعادة المعلومات المرتبطة بالملف الذي يشير إليه الاختصار.

التابع Path.mkdir

يُنشئ هذا التابع مجلّدًا في المسار المُعطى بالخصائص التي يتم تحديدها في باقي الوسطاء.

التابع Path.open

يفتح الملف الذي يشير إليه المسار، بطريقة مشابهة للتابع المضمن open

>>> p = Path('setup.py')

>>> with p.open() as f:
...    .readline()
...
'#!/usr/bin/env python3\n'

التابع Path.owner

يعيد هذا التابع اسم المستخدم المالك للملف. ويرمي استثناءً KeyError إن كان معرف المستخدم uid غير موجود في قاعدة بيانات النظام.

التابع Path.read_bytes

يعيد هذا التابع المحتوى المرمّز للملف المُشار إليه ككائن من النوع bytes

>>> p = Path('my_binary_file')

>>> p.write_bytes(b'Binary file contents')
20

>>> p.read_bytes()
b'Binary file contents'

تم استحداث هذا التابع في النسخة 3.5

التابع Path.read_text

يعيد هذا التابع المحتوى النصي للملف كسلسلة نصية

>>> p = Path('my_text_file')

>>> p.write_text('Text file contents')
18

>>> p.read_text()
'Text file contents'

تأخذ الوسطاء الاختيارية نفس المعاني الخاصة بها في التابع المضمن open

تم استحداث هذا التابع في النسخة 3.5

التابع Path.rename

يعيد تسمية الملف أو المجلد بما يحدده الوسيط المُعطى. في نظام يونكس، إذا كان اسم الملف بعد إعادة التسمية موجودًا فعلًا كملف، فإنه يُستبدل دون أي إنذار إذا لدى المستخدم الصلاحيات اللازمة لذلك.

يمكن أن يكون الوسيط الي يحدد اسم الملف بعد إعادة التسمية سلسلة نصية أو كائن مسار آخر.

>>> p = Path('foo')

>>> p.open('w').write('some text')
9

>>> target = Path('bar')

>>> p.rename(target)

>>> target.open().read()
'some text'

التابع Path.replace

يستبدل الملف الحالي بملف الوجهة، حيث يقوم بإعادة التسمية إن لم تكن الوجهة موجودة، ويقوم بالاستبدال دون أي شرط في حال كانت الوجهة موجودة من قبل.

التابع Path.resolve

يجعل المسار مسارًا مطلقًا.

التابع Path.rglob

مشابه لاستدعاء التابع glob عند إضافة '**' في بداية النمط المُعطى

>>> sorted(Path().rglob("*.py"))
[PosixPath('build/lib/pathlib.py'),
PosixPath('docs/conf.py'),
PosixPath('pathlib.py'),
PosixPath('setup.py'),
PosixPath('test_pathlib.py')]

التابع Path.rmdir

يحذف المجلد إن كان خاليًا من الملفات.

التابع Path.samefile

يحدد فيما إذا كان المسار المعطى هو مطابقًا للمسار الخاص بالكائن.

التابع Path.symlink_to

يجعل من الكائن اختصارًا للملف المُعطى.

التابع Path.touch

يُنشئ ملفًّا في المسار المُعطى.

التابع Path.unlink

يحذف الملف أو الاختصار الذي يشير إليه الكائن، أما إذا كان المسار يشير إلى مجلد فيجب استخدام التابع Path.rmdir بدلًا من هذا التابع.

التابع Path.write_bytes

يفتح الملف المُشار إليه في نمط bytes، ويكتب البيانات فيه ثم يُغلقه.

>>> p = Path('my_binary_file')

>>> p.write_bytes(b'Binary file contents')
20

>>> p.read_bytes()
b'Binary file contents'

إن كان المسار يشير إلى ملف موجود مسبقًا، فإن الكتابة عليه تؤدي إلى حذف المحتوى السابق.

تابع مُستحدث في السخة 3.5.

التابع Path.write_text

يفتح الملف المٌشار إليه بالنمط النصي، ويكتب البيانات فيه ثم يُغلقه.

>>> p = Path('my_text_file')

>>> p.write_text('Text file contents')
18

>>> p.read_text()
'Text file contents'

<span> </span>

<span> </span>

تابع مُستحدث في السخة 3.5.

انظر أيضًا

للقيام بمعالجة منخفضة المستوى للمسارات على السلاسل النصية، يمكنك أيضًا استخدام الوحدة os.path

التقابل مع الوحدة os

يبيّن الجدول التالي تقابل عدة توابع من الوحدة os  مع ما يقابلها و يكافئها من الوحدة Path.

الوحدة os والوحدة os.path الوحدة pathlib
os.path.abspath() Path.resolve()
os.getcwd() Path.cwd()
os.path.exists() Path.exists()
os.path.expanduser() Path.expanduser() و Path.home()
os.path.isdir() Path.is_dir()
os.path.isfile() Path.is_file()
os.path.islink() Path.is_symlink()
os.stat() Path.stat(),Path.owner(), Path.group()

ملاحظة:

بالرغم من وجود بعض التقاطع في حالات استخدام التابعين os.path.relpath‎‎()‎ والتابع PurePath.relative_to()‎ إلا أن مدلول كل منهما مختلف بما يدعو لعدم اعتبارهما متكافئين.