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

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
(عمل في التوابع)
سطر 50: سطر 50:
  
 
</syntaxhighlight><span> </span>
 
</syntaxhighlight><span> </span>
 
+
===نكهات المسارات الصلبة===
=== نكهات المسارات الصلبة ===
 
 
يمكن إنشاء كائن من الصنف <code>Path</code> بثلاث طرق مختلفة:
 
يمكن إنشاء كائن من الصنف <code>Path</code> بثلاث طرق مختلفة:
  
سطر 105: سطر 104:
 
===توابع الصنف <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()
سطر 114: سطر 112:
  
 
</syntaxhighlight>
 
</syntaxhighlight>
 
+
====التابع <code>Path.home</code>====
==== التابع <code>Path.home</code> ====
 
 
يعيد كائن مسار جديدًا يمثّل المسار الرئيسي (home directory) للمستخدم (بشكل مشابه للتابع os.path.expanduser مع الوسيط <code>'~'</code>)
 
يعيد كائن مسار جديدًا يمثّل المسار الرئيسي (home directory) للمستخدم (بشكل مشابه للتابع os.path.expanduser مع الوسيط <code>'~'</code>)
  
سطر 125: سطر 122:
  
 
</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')
سطر 140: سطر 136:
  
 
</syntaxhighlight>
 
</syntaxhighlight>
 
+
====التابع <code>Path.chmod</code>====
==== التابع <code>Path.chmod</code> ====
 
 
يقوم هذا التابع بتغيير نمط الملف وصلاحياته (مماثل للتابع <code>os.chmod</code>)<syntaxhighlight lang="python3">
 
يقوم هذا التابع بتغيير نمط الملف وصلاحياته (مماثل للتابع <code>os.chmod</code>)<syntaxhighlight lang="python3">
 
>>>
 
>>>
سطر 159: سطر 154:
  
 
</syntaxhighlight>
 
</syntaxhighlight>
 
+
====التابع <code>Path.exists</code>====
==== التابع <code>Path.exists</code> ====
 
 
يدلّ على كون المسار مشيرًا إلى ملف أو مجلد حقيقي أم لا<syntaxhighlight lang="python3">
 
يدلّ على كون المسار مشيرًا إلى ملف أو مجلد حقيقي أم لا<syntaxhighlight lang="python3">
 
>>>
 
>>>
سطر 182: سطر 176:
  
 
</syntaxhighlight>ملاحظة: إذا كان المسار يشير إلى اختصار (symlink) فإن استدعاء التابع <code>exists</code> يدل على ما يشير إليه الاختصار.
 
</syntaxhighlight>ملاحظة: إذا كان المسار يشير إلى اختصار (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">
 
>>>
 
>>>
سطر 194: سطر 187:
  
 
</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">
Glob the given pattern in the directory represented by this path, yielding all matching files (of any kind):
 
 
 
 
>>>
 
>>>
  
سطر 208: سطر 199:
 
[PosixPath('docs/conf.py')]
 
[PosixPath('docs/conf.py')]
  
The “**” pattern means “this directory and all subdirectories, recursively”. In other words, it enables recursive globbing:
 
  
 +
</syntaxhighlight>يعني النمط <code>"**"</code> تحديد المجلد الحالي وجميه المجلدات الفرعية في داخله بشكل عودي (recursively)، وهو ما يسمّى recursive globbing<syntaxhighlight lang="python3">
 
>>>
 
>>>
  
سطر 224: سطر 215:
 
PosixPath('test_pathlib.py')]
 
PosixPath('test_pathlib.py')]
  
Note
 
 
Using the “**” pattern in large directory trees may consume an inordinate amount of time.
 
 
==== التابع <code>Path.group</code> ====
 
Return the name of the group owning the file. KeyError is raised if the file’s gid isn’t found in the system database.
 
  
==== التابع <code>Path.is_dir</code> ====
+
</syntaxhighlight>ملاحظة: احذر من استخدام النمط <code>"**"</code> في أشجار المجلدات الكبيرة، فإن ذلك قد يستهلك كمية هائلة من الوقت,
Return True if the path points to a directory (or a symbolic link pointing to a directory), False if it points to another kind of file.
+
====التابع <code>Path.group</code>====
 
+
يعيد هذا التابع اسم المجموعة التي ينتمي لها الملف، ويرمي بالخطأ <code>KeyError</code>  إذا كان معرف المجموعة <code>gid</code> الخاص بالملف غير موجود في قاعدة بيانات النظام.
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
+
====التابع <code>Path.is_dir</code>====
 +
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى مجلد (أو إلى اختصار يشير إلى مجلد)، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
==== التابع <code>Path.is_file</code> ====
+
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
Return True if the path points to a regular file (or a symbolic link pointing to a regular file), False if it points to another kind of file.
+
====التابع <code>Path.is_file</code>====
 +
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى ملف نظامي(أو إلى اختصار يشير إلى ملف نظامي)، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
+
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
  
 
التابع <code>Path.is_mount</code>
 
التابع <code>Path.is_mount</code>
  
Return True if the path is a mount point: a point in a file system where a different file system has been mounted. On POSIX, the function checks whether path’s parent, path/.., is on a different device than path, or whether path/.. and path point to the same i-node on the same device — this should detect mount points for all Unix and POSIX variants. Not implemented on Windows.
+
يعيد هذا التابع القيمة المنطقية <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>True</code> إذا كان المسار يشير إلى رابط دلالي (symbolic link)، و<code>False</code> فيما عدا ذلك.
  
New in version 3.7.
+
كما أنه عيد <code>False</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>Path.is_symlink</code> ====
+
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
Return True if the path points to a symbolic link, False otherwise.
+
====التابع <code>Path.is_fifo</code>====
 +
يعيد هذا التابع القيمة المنطقية <code>True</code> إذا كان المسار يشير إلى [[wikipedia:Named_pipe|FIFO]] (أو إلى اختصار يشير إلى [[wikipedia:Named_pipe|FIFO]])، بينما يعيد <code>False</code> في حال كان المسار يشير إلى أي نوع آخر من الملفات.
  
False is also returned if the path doesn’t exist; other errors (such as permission errors) are propagated.
+
كما أنه عيد <code>False</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>Path.is_socket</code> ====
+
كما أنه عيد <code>False</code> إذا كان المسار غير موجود أو أن الاختصار بشير إلى مسار غير موجود، كما يمكن لأخطاء أخرى (مثل عدم وجود صلاحيات) أن تظهر.
Return True if the path points to a Unix socket (or a symbolic link pointing to a Unix socket), False if it points to another kind of file.
+
====التابع <code>Path.is_char_device</code>====
 
 
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
 
 
 
==== التابع <code>Path.is_fifo</code> ====
 
Return True if the path points to a FIFO (or a symbolic link pointing to a FIFO), False if it points to another kind of file.
 
 
 
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
 
 
 
==== التابع <code>Path.is_block_device</code> ====
 
Return True if the path points to a block device (or a symbolic link pointing to a block device), False if it points to another kind of file.
 
 
 
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
 
 
 
==== التابع <code>Path.is_char_device</code> ====
 
 
Return True if the path points to a character device (or a symbolic link pointing to a character device), Falseif it points to another kind of file.
 
Return True if the path points to a character device (or a symbolic link pointing to a character device), Falseif it points to another kind of file.
  
 
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
 
False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.
 
+
====التابع <code>Path.iterdir</code>====
==== التابع <code>Path.iterdir</code> ====
 
 
When the path points to a directory, yield path objects of the directory contents:
 
When the path points to a directory, yield path objects of the directory contents:
  
سطر 296: سطر 275:
  
 
PosixPath('docs/Makefile')
 
PosixPath('docs/Makefile')
 
+
====التابع <code>Path.lchmod</code>====
==== التابع <code>Path.lchmod</code> ====
 
 
Like Path.chmod() but, if the path points to a symbolic link, the symbolic link’s mode is changed rather than its target’s.
 
Like Path.chmod() but, if the path points to a symbolic link, the symbolic link’s mode is changed rather than its target’s.
 
+
====التابع <code>Path.lstat</code>====
==== التابع <code>Path.lstat</code> ====
 
 
Like Path.stat() but, if the path points to a symbolic link, return the symbolic link’s information rather than its target’s.
 
Like Path.stat() but, if the path points to a symbolic link, return the symbolic link’s information rather than its target’s.
 
+
====التابع <code>Path.mkdir</code>====
==== التابع <code>Path.mkdir</code> ====
 
 
Create a new directory at this given path. If mode is given, it is combined with the process’ umask value to determine the file mode and access flags. If the path already exists, FileExistsError is raised.
 
Create a new directory at this given path. If mode is given, it is combined with the process’ umask value to determine the file mode and access flags. If the path already exists, FileExistsError is raised.
  
سطر 315: سطر 291:
  
 
Changed in version 3.5: The exist_ok parameter was added.
 
Changed in version 3.5: The exist_ok parameter was added.
 
+
====التابع <code>Path.open</code>====
==== التابع <code>Path.open</code> ====
 
 
Open the file pointed to by the path, like the built-in open() function does:
 
Open the file pointed to by the path, like the built-in open() function does:
  
سطر 330: سطر 305:
  
 
'#!/usr/bin/env python3\n'
 
'#!/usr/bin/env python3\n'
 
+
====التابع <code>Path.owner</code>====
==== التابع <code>Path.owner</code> ====
 
 
Return the name of the user owning the file. KeyError is raised if the file’s uid isn’t found in the system database.
 
Return the name of the user owning the file. KeyError is raised if the file’s uid isn’t found in the system database.
 
+
====التابع <code>Path.read_bytes</code>====
==== التابع <code>Path.read_bytes</code> ====
 
 
Return the binary contents of the pointed-to file as a bytes object:
 
Return the binary contents of the pointed-to file as a bytes object:
  
سطر 350: سطر 323:
  
 
New in version 3.5.
 
New in version 3.5.
 
+
====التابع <code>Path.read_text</code>====
==== التابع <code>Path.read_text</code> ====
 
 
Return the decoded contents of the pointed-to file as a string:
 
Return the decoded contents of the pointed-to file as a string:
  
سطر 369: سطر 341:
  
 
New in version 3.5.
 
New in version 3.5.
 
+
====التابع <code>Path.rename</code>====
==== التابع <code>Path.rename</code> ====
 
 
Rename this file or directory to the given target. On Unix, if target exists and is a file, it will be replaced silently if the user has permission. target can be either a string or another path object:
 
Rename this file or directory to the given target. On Unix, if target exists and is a file, it will be replaced silently if the user has permission. target can be either a string or another path object:
  
سطر 388: سطر 359:
  
 
'some text'
 
'some text'
 
+
====التابع <code>Path.replace</code>====
==== التابع <code>Path.replace</code> ====
 
 
Rename this file or directory to the given target. If target points to an existing file or directory, it will be unconditionally replaced.
 
Rename this file or directory to the given target. If target points to an existing file or directory, it will be unconditionally replaced.
 
+
====التابع <code>Path.resolve</code>====
==== التابع <code>Path.resolve</code> ====
 
 
Make the path absolute, resolving any symlinks. A new path object is returned:
 
Make the path absolute, resolving any symlinks. A new path object is returned:
  
سطر 420: سطر 389:
  
 
New in version 3.6: The strict argument.
 
New in version 3.6: The strict argument.
 
+
====التابع <code>Path.rglob</code>====
==== التابع <code>Path.rglob</code> ====
 
 
This is like calling Path.glob() with “**” added in front of the given pattern:
 
This is like calling Path.glob() with “**” added in front of the given pattern:
  
سطر 441: سطر 409:
  
 
Remove this directory. The directory must be empty.
 
Remove this directory. The directory must be empty.
 
+
====التابع <code>Path.samefile</code>====
==== التابع <code>Path.samefile</code> ====
 
 
Return whether this path points to the same file as other_path, which can be either a Path object, or a string. The semantics are similar to os.path.samefile() and os.path.samestat().
 
Return whether this path points to the same file as other_path, which can be either a Path object, or a string. The semantics are similar to os.path.samefile() and os.path.samestat().
  
سطر 462: سطر 429:
  
 
New in version 3.5.
 
New in version 3.5.
 
+
====التابع <code>Path.symlink_to</code>====
==== التابع <code>Path.symlink_to</code> ====
 
 
Make this path a symbolic link to target. Under Windows, target_is_directory must be true (default False) if the link’s target is a directory. Under POSIX, target_is_directory’s value is ignored.
 
Make this path a symbolic link to target. Under Windows, target_is_directory must be true (default False) if the link’s target is a directory. Under POSIX, target_is_directory’s value is ignored.
  
سطر 487: سطر 453:
  
 
The order of arguments (link, target) is the reverse of os.symlink()’s.
 
The order of arguments (link, target) is the reverse of os.symlink()’s.
 
+
====التابع <code>Path.touch</code>====
==== التابع <code>Path.touch</code> ====
 
 
Create a file at this given path. If mode is given, it is combined with the process’ umask value to determine the file mode and access flags. If the file already exists, the function succeeds if exist_ok is true (and its modification time is updated to the current time), otherwise FileExistsError is raised.
 
Create a file at this given path. If mode is given, it is combined with the process’ umask value to determine the file mode and access flags. If the file already exists, the function succeeds if exist_ok is true (and its modification time is updated to the current time), otherwise FileExistsError is raised.
 
+
====التابع <code>Path.unlink</code>====
==== التابع <code>Path.unlink</code> ====
 
 
Remove this file or symbolic link. If the path points to a directory, use Path.rmdir() instead.
 
Remove this file or symbolic link. If the path points to a directory, use Path.rmdir() instead.
 
+
====التابع <code>Path.write_bytes</code>====
==== التابع <code>Path.write_bytes</code> ====
 
 
Open the file pointed to in bytes mode, write data to it, and close the file:
 
Open the file pointed to in bytes mode, write data to it, and close the file:
  
سطر 512: سطر 475:
  
 
New in version 3.5.
 
New in version 3.5.
 
+
====التابع <code>Path.write_text</code>====
==== التابع <code>Path.write_text</code> ====
 
 
Open the file pointed to in text mode, write data to it, and close the file:
 
Open the file pointed to in text mode, write data to it, and close the file:
  
سطر 527: سطر 489:
  
 
'Text file contents'
 
'Text file contents'
 +
 +
<span> </span>
  
 
<span> </span>
 
<span> </span>
  
 
New in version 3.5.
 
New in version 3.5.

مراجعة 21:50، 29 يوليو 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

Return True if the path points to a character device (or a symbolic link pointing to a character device), Falseif it points to another kind of file.

False is also returned if the path doesn’t exist or is a broken symlink; other errors (such as permission errors) are propagated.

التابع Path.iterdir

When the path points to a directory, yield path objects of the directory contents:

>>>

>>> 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

Like Path.chmod() but, if the path points to a symbolic link, the symbolic link’s mode is changed rather than its target’s.

التابع Path.lstat

Like Path.stat() but, if the path points to a symbolic link, return the symbolic link’s information rather than its target’s.

التابع Path.mkdir

Create a new directory at this given path. If mode is given, it is combined with the process’ umask value to determine the file mode and access flags. If the path already exists, FileExistsError is raised.

If parents is true, any missing parents of this path are created as needed; they are created with the default permissions without taking mode into account (mimicking the POSIX mkdir -p command).

If parents is false (the default), a missing parent raises FileNotFoundError.

If exist_ok is false (the default), FileExistsError is raised if the target directory already exists.

If exist_ok is true, FileExistsError exceptions will be ignored (same behavior as the POSIX mkdir -pcommand), but only if the last path component is not an existing non-directory file.

Changed in version 3.5: The exist_ok parameter was added.

التابع Path.open

Open the file pointed to by the path, like the built-in open() function does:

>>>

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

>>> with p.open() as f:

...    .readline()

...

'#!/usr/bin/env python3\n'

التابع Path.owner

Return the name of the user owning the file. KeyError is raised if the file’s uid isn’t found in the system database.

التابع Path.read_bytes

Return the binary contents of the pointed-to file as a bytes object:

>>>

>>> p = Path('my_binary_file')

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

20

>>> p.read_bytes()

b'Binary file contents'

New in version 3.5.

التابع Path.read_text

Return the decoded contents of the pointed-to file as a string:

>>>

>>> p = Path('my_text_file')

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

18

>>> p.read_text()

'Text file contents'

The optional parameters have the same meaning as in open().

New in version 3.5.

التابع Path.rename

Rename this file or directory to the given target. On Unix, if target exists and is a file, it will be replaced silently if the user has permission. target can be either a string or another path object:

>>>

>>> p = Path('foo')

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

9

>>> target = Path('bar')

>>> p.rename(target)

>>> target.open().read()

'some text'

التابع Path.replace

Rename this file or directory to the given target. If target points to an existing file or directory, it will be unconditionally replaced.

التابع Path.resolve

Make the path absolute, resolving any symlinks. A new path object is returned:

>>>

>>> p = Path()

>>> p

PosixPath('.')

>>> p.resolve()

PosixPath('/home/antoine/pathlib')

“..” components are also eliminated (this is the only method to do so):

>>>

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

>>> p.resolve()

PosixPath('/home/antoine/pathlib/setup.py')

If the path doesn’t exist and strict is True, FileNotFoundError is raised. If strict is False, the path is resolved as far as possible and any remainder is appended without checking whether it exists. If an infinite loop is encountered along the resolution path, RuntimeError is raised.

New in version 3.6: The strict argument.

التابع Path.rglob

This is like calling Path.glob() with “**” added in front of the given pattern:

>>>

>>> 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()

Remove this directory. The directory must be empty.

التابع Path.samefile

Return whether this path points to the same file as other_path, which can be either a Path object, or a string. The semantics are similar to os.path.samefile() and os.path.samestat().

An OSError can be raised if either file cannot be accessed for some reason.

>>>

>>> p = Path('spam')

>>> q = Path('eggs')

>>> p.samefile(q)

False

>>> p.samefile('spam')

True

New in version 3.5.

التابع Path.symlink_to

Make this path a symbolic link to target. Under Windows, target_is_directory must be true (default False) if the link’s target is a directory. Under POSIX, target_is_directory’s value is ignored.

>>>

>>> p = Path('mylink')

>>> p.symlink_to('setup.py')

>>> p.resolve()

PosixPath('/home/antoine/pathlib/setup.py')

>>> p.stat().st_size

956

>>> p.lstat().st_size

8

Note

The order of arguments (link, target) is the reverse of os.symlink()’s.

التابع Path.touch

Create a file at this given path. If mode is given, it is combined with the process’ umask value to determine the file mode and access flags. If the file already exists, the function succeeds if exist_ok is true (and its modification time is updated to the current time), otherwise FileExistsError is raised.

التابع Path.unlink

Remove this file or symbolic link. If the path points to a directory, use Path.rmdir() instead.

التابع Path.write_bytes

Open the file pointed to in bytes mode, write data to it, and close the file:

>>>

>>> p = Path('my_binary_file')

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

20

>>> p.read_bytes()

b'Binary file contents'

An existing file of the same name is overwritten.

New in version 3.5.

التابع Path.write_text

Open the file pointed to in text mode, write data to it, and close the file:

>>>

>>> p = Path('my_text_file')

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

18

>>> p.read_text()

'Text file contents'

New in version 3.5.