blob: 05c5d722ef7def5fc564fdae162287dbc5a748e6 [file] [log] [blame]
Antoine Pitrou31119e42013-11-22 17:38:12 +01001
2:mod:`pathlib` --- Object-oriented filesystem paths
3===================================================
4
5.. module:: pathlib
6 :synopsis: Object-oriented filesystem paths
7
8.. index:: single: path; operations
9
10.. versionadded:: 3.4
11
Antoine Pitrou31119e42013-11-22 17:38:12 +010012This module offers classes representing filesystem paths with semantics
13appropriate for different operating systems. Path classes are divided
14between :ref:`pure paths <pure-paths>`, which provide purely computational
15operations without I/O, and :ref:`concrete paths <concrete-paths>`, which
16inherit from pure paths but also provide I/O operations.
17
Eli Benderskyb6e66eb2013-11-28 06:53:05 -080018.. image:: pathlib-inheritance.png
19 :align: center
20
21If you've never used this module before or just aren't sure which class is
22right for your task, :class:`Path` is most likely what you need. It instantiates
23a :ref:`concrete path <concrete-paths>` for the platform the code is running on.
24
25Pure paths are useful in some special cases; for example:
26
27#. If you want to manipulate Windows paths on a Unix machine (or vice versa).
28 You cannot instantiate a :class:`WindowsPath` when running on Unix, but you
29 can instantiate :class:`PureWindowsPath`.
30#. You want to make sure that your code only manipulates paths without actually
31 accessing the OS. In this case, instantiating one of the pure classes may be
32 useful since those simply don't have any OS-accessing operations.
Antoine Pitrou31119e42013-11-22 17:38:12 +010033
34.. note::
Andrew Kuchling7a4e2d12013-11-22 15:45:02 -050035 This module has been included in the standard library on a
Antoine Pitrou31119e42013-11-22 17:38:12 +010036 :term:`provisional basis <provisional package>`. Backwards incompatible
37 changes (up to and including removal of the package) may occur if deemed
38 necessary by the core developers.
39
40.. seealso::
41 :pep:`428`: The pathlib module -- object-oriented filesystem paths.
42
43.. seealso::
44 For low-level path manipulation on strings, you can also use the
45 :mod:`os.path` module.
46
47
48Basic use
49---------
50
51Importing the main class::
52
53 >>> from pathlib import Path
54
55Listing subdirectories::
56
57 >>> p = Path('.')
58 >>> [x for x in p.iterdir() if x.is_dir()]
59 [PosixPath('.hg'), PosixPath('docs'), PosixPath('dist'),
60 PosixPath('__pycache__'), PosixPath('build')]
61
62Listing Python source files in this directory tree::
63
64 >>> list(p.glob('**/*.py'))
65 [PosixPath('test_pathlib.py'), PosixPath('setup.py'),
66 PosixPath('pathlib.py'), PosixPath('docs/conf.py'),
67 PosixPath('build/lib/pathlib.py')]
68
69Navigating inside a directory tree::
70
71 >>> p = Path('/etc')
72 >>> q = p / 'init.d' / 'reboot'
73 >>> q
74 PosixPath('/etc/init.d/reboot')
75 >>> q.resolve()
76 PosixPath('/etc/rc.d/init.d/halt')
77
78Querying path properties::
79
80 >>> q.exists()
81 True
82 >>> q.is_dir()
83 False
84
85Opening a file::
86
87 >>> with q.open() as f: f.readline()
88 ...
89 '#!/bin/bash\n'
90
91
92.. _pure-paths:
93
94Pure paths
95----------
96
97Pure path objects provide path-handling operations which don't actually
98access a filesystem. There are three ways to access these classes, which
99we also call *flavours*:
100
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800101.. class:: PurePath(*pathsegments)
Antoine Pitrou31119e42013-11-22 17:38:12 +0100102
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800103 A generic class that represents the system's path flavour (instantiating
104 it creates either a :class:`PurePosixPath` or a :class:`PureWindowsPath`)::
105
106 >>> PurePath('setup.py') # Running on a Unix machine
107 PurePosixPath('setup.py')
108
Antoine Pitrou8ad751e2015-04-12 00:08:02 +0200109 Each element of *pathsegments* can be either a string representing a
110 path segment, or another path object::
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800111
112 >>> PurePath('foo', 'some/path', 'bar')
113 PurePosixPath('foo/some/path/bar')
114 >>> PurePath(Path('foo'), Path('bar'))
115 PurePosixPath('foo/bar')
116
117 When *pathsegments* is empty, the current directory is assumed::
118
119 >>> PurePath()
120 PurePosixPath('.')
121
122 When several absolute paths are given, the last is taken as an anchor
123 (mimicking :func:`os.path.join`'s behaviour)::
124
125 >>> PurePath('/etc', '/usr', 'lib64')
126 PurePosixPath('/usr/lib64')
127 >>> PureWindowsPath('c:/Windows', 'd:bar')
128 PureWindowsPath('d:bar')
129
130 However, in a Windows path, changing the local root doesn't discard the
131 previous drive setting::
132
133 >>> PureWindowsPath('c:/Windows', '/Program Files')
134 PureWindowsPath('c:/Program Files')
135
136 Spurious slashes and single dots are collapsed, but double dots (``'..'``)
137 are not, since this would change the meaning of a path in the face of
138 symbolic links::
139
140 >>> PurePath('foo//bar')
141 PurePosixPath('foo/bar')
142 >>> PurePath('foo/./bar')
143 PurePosixPath('foo/bar')
144 >>> PurePath('foo/../bar')
145 PurePosixPath('foo/../bar')
146
147 (a naïve approach would make ``PurePosixPath('foo/../bar')`` equivalent
148 to ``PurePosixPath('bar')``, which is wrong if ``foo`` is a symbolic link
149 to another directory)
150
151.. class:: PurePosixPath(*pathsegments)
Antoine Pitrou31119e42013-11-22 17:38:12 +0100152
153 A subclass of :class:`PurePath`, this path flavour represents non-Windows
154 filesystem paths::
155
156 >>> PurePosixPath('/etc')
157 PurePosixPath('/etc')
158
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800159 *pathsegments* is specified similarly to :class:`PurePath`.
160
161.. class:: PureWindowsPath(*pathsegments)
Antoine Pitrou31119e42013-11-22 17:38:12 +0100162
163 A subclass of :class:`PurePath`, this path flavour represents Windows
164 filesystem paths::
165
166 >>> PureWindowsPath('c:/Program Files/')
167 PureWindowsPath('c:/Program Files')
168
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800169 *pathsegments* is specified similarly to :class:`PurePath`.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100170
171Regardless of the system you're running on, you can instantiate all of
172these classes, since they don't provide any operation that does system calls.
173
174
Antoine Pitrou31119e42013-11-22 17:38:12 +0100175General properties
176^^^^^^^^^^^^^^^^^^
177
178Paths are immutable and hashable. Paths of a same flavour are comparable
179and orderable. These properties respect the flavour's case-folding
180semantics::
181
182 >>> PurePosixPath('foo') == PurePosixPath('FOO')
183 False
184 >>> PureWindowsPath('foo') == PureWindowsPath('FOO')
185 True
186 >>> PureWindowsPath('FOO') in { PureWindowsPath('foo') }
187 True
188 >>> PureWindowsPath('C:') < PureWindowsPath('d:')
189 True
190
191Paths of a different flavour compare unequal and cannot be ordered::
192
193 >>> PureWindowsPath('foo') == PurePosixPath('foo')
194 False
195 >>> PureWindowsPath('foo') < PurePosixPath('foo')
196 Traceback (most recent call last):
197 File "<stdin>", line 1, in <module>
198 TypeError: unorderable types: PureWindowsPath() < PurePosixPath()
199
200
201Operators
202^^^^^^^^^
203
204The slash operator helps create child paths, similarly to :func:`os.path.join`::
205
206 >>> p = PurePath('/etc')
207 >>> p
208 PurePosixPath('/etc')
209 >>> p / 'init.d' / 'apache2'
210 PurePosixPath('/etc/init.d/apache2')
211 >>> q = PurePath('bin')
212 >>> '/usr' / q
213 PurePosixPath('/usr/bin')
214
215The string representation of a path is the raw filesystem path itself
216(in native form, e.g. with backslashes under Windows), which you can
217pass to any function taking a file path as a string::
218
219 >>> p = PurePath('/etc')
220 >>> str(p)
221 '/etc'
222 >>> p = PureWindowsPath('c:/Program Files')
223 >>> str(p)
224 'c:\\Program Files'
225
226Similarly, calling :class:`bytes` on a path gives the raw filesystem path as a
227bytes object, as encoded by :func:`os.fsencode`::
228
229 >>> bytes(p)
230 b'/etc'
231
232.. note::
233 Calling :class:`bytes` is only recommended under Unix. Under Windows,
234 the unicode form is the canonical representation of filesystem paths.
235
236
237Accessing individual parts
238^^^^^^^^^^^^^^^^^^^^^^^^^^
239
240To access the individual "parts" (components) of a path, use the following
241property:
242
243.. data:: PurePath.parts
244
245 A tuple giving access to the path's various components::
246
247 >>> p = PurePath('/usr/bin/python3')
248 >>> p.parts
249 ('/', 'usr', 'bin', 'python3')
250
251 >>> p = PureWindowsPath('c:/Program Files/PSF')
252 >>> p.parts
253 ('c:\\', 'Program Files', 'PSF')
254
255 (note how the drive and local root are regrouped in a single part)
256
257
258Methods and properties
259^^^^^^^^^^^^^^^^^^^^^^
260
Andrew Kuchling7a4e2d12013-11-22 15:45:02 -0500261Pure paths provide the following methods and properties:
Antoine Pitrou31119e42013-11-22 17:38:12 +0100262
263.. data:: PurePath.drive
264
265 A string representing the drive letter or name, if any::
266
267 >>> PureWindowsPath('c:/Program Files/').drive
268 'c:'
269 >>> PureWindowsPath('/Program Files/').drive
270 ''
271 >>> PurePosixPath('/etc').drive
272 ''
273
274 UNC shares are also considered drives::
275
276 >>> PureWindowsPath('//host/share/foo.txt').drive
277 '\\\\host\\share'
278
279.. data:: PurePath.root
280
281 A string representing the (local or global) root, if any::
282
283 >>> PureWindowsPath('c:/Program Files/').root
284 '\\'
285 >>> PureWindowsPath('c:Program Files/').root
286 ''
287 >>> PurePosixPath('/etc').root
288 '/'
289
290 UNC shares always have a root::
291
292 >>> PureWindowsPath('//host/share').root
293 '\\'
294
295.. data:: PurePath.anchor
296
297 The concatenation of the drive and root::
298
299 >>> PureWindowsPath('c:/Program Files/').anchor
300 'c:\\'
301 >>> PureWindowsPath('c:Program Files/').anchor
302 'c:'
303 >>> PurePosixPath('/etc').anchor
304 '/'
305 >>> PureWindowsPath('//host/share').anchor
306 '\\\\host\\share\\'
307
308
309.. data:: PurePath.parents
310
311 An immutable sequence providing access to the logical ancestors of
312 the path::
313
314 >>> p = PureWindowsPath('c:/foo/bar/setup.py')
315 >>> p.parents[0]
316 PureWindowsPath('c:/foo/bar')
317 >>> p.parents[1]
318 PureWindowsPath('c:/foo')
319 >>> p.parents[2]
320 PureWindowsPath('c:/')
321
322
323.. data:: PurePath.parent
324
325 The logical parent of the path::
326
327 >>> p = PurePosixPath('/a/b/c/d')
328 >>> p.parent
329 PurePosixPath('/a/b/c')
330
331 You cannot go past an anchor, or empty path::
332
333 >>> p = PurePosixPath('/')
334 >>> p.parent
335 PurePosixPath('/')
336 >>> p = PurePosixPath('.')
337 >>> p.parent
338 PurePosixPath('.')
339
340 .. note::
341 This is a purely lexical operation, hence the following behaviour::
342
343 >>> p = PurePosixPath('foo/..')
344 >>> p.parent
345 PurePosixPath('foo')
346
347 If you want to walk an arbitrary filesystem path upwards, it is
348 recommended to first call :meth:`Path.resolve` so as to resolve
349 symlinks and eliminate `".."` components.
350
351
352.. data:: PurePath.name
353
354 A string representing the final path component, excluding the drive and
355 root, if any::
356
357 >>> PurePosixPath('my/library/setup.py').name
358 'setup.py'
359
360 UNC drive names are not considered::
361
362 >>> PureWindowsPath('//some/share/setup.py').name
363 'setup.py'
364 >>> PureWindowsPath('//some/share').name
365 ''
366
367
Guido van Rossumdf859462016-01-06 11:15:52 -0800368.. data:: PurePath.path
369
370 A string representing the full path::
371
372 >>> PurePosixPath('my/library/setup.py').path
373 'my/library/setup.py'
374
375 This always returns the same value as ``str(p)``; it is included to
376 serve as a one-off protocol. Code that wants to support both
377 strings and ``pathlib.Path`` objects as filenames can write
378 ``arg = getattr(arg, 'path', arg)`` to get the path as a string.
379 This can then be passed to various system calls or library
380 functions that expect a string. Unlike the alternative
381 ``arg = str(arg)``, this will still raise an exception if an object
382 of some other type is given by accident.
383
384
Antoine Pitrou31119e42013-11-22 17:38:12 +0100385.. data:: PurePath.suffix
386
387 The file extension of the final component, if any::
388
389 >>> PurePosixPath('my/library/setup.py').suffix
390 '.py'
391 >>> PurePosixPath('my/library.tar.gz').suffix
392 '.gz'
393 >>> PurePosixPath('my/library').suffix
394 ''
395
396
397.. data:: PurePath.suffixes
398
399 A list of the path's file extensions::
400
401 >>> PurePosixPath('my/library.tar.gar').suffixes
402 ['.tar', '.gar']
403 >>> PurePosixPath('my/library.tar.gz').suffixes
404 ['.tar', '.gz']
405 >>> PurePosixPath('my/library').suffixes
406 []
407
408
409.. data:: PurePath.stem
410
411 The final path component, without its suffix::
412
413 >>> PurePosixPath('my/library.tar.gz').stem
414 'library.tar'
415 >>> PurePosixPath('my/library.tar').stem
416 'library'
417 >>> PurePosixPath('my/library').stem
418 'library'
419
420
421.. method:: PurePath.as_posix()
422
423 Return a string representation of the path with forward slashes (``/``)::
424
425 >>> p = PureWindowsPath('c:\\windows')
426 >>> str(p)
427 'c:\\windows'
428 >>> p.as_posix()
429 'c:/windows'
430
431
432.. method:: PurePath.as_uri()
433
434 Represent the path as a ``file`` URI. :exc:`ValueError` is raised if
435 the path isn't absolute.
436
437 >>> p = PurePosixPath('/etc/passwd')
438 >>> p.as_uri()
439 'file:///etc/passwd'
440 >>> p = PureWindowsPath('c:/Windows')
441 >>> p.as_uri()
442 'file:///c:/Windows'
443
444
445.. method:: PurePath.is_absolute()
446
447 Return whether the path is absolute or not. A path is considered absolute
448 if it has both a root and (if the flavour allows) a drive::
449
450 >>> PurePosixPath('/a/b').is_absolute()
451 True
452 >>> PurePosixPath('a/b').is_absolute()
453 False
454
455 >>> PureWindowsPath('c:/a/b').is_absolute()
456 True
457 >>> PureWindowsPath('/a/b').is_absolute()
458 False
459 >>> PureWindowsPath('c:').is_absolute()
460 False
461 >>> PureWindowsPath('//some/share').is_absolute()
462 True
463
464
465.. method:: PurePath.is_reserved()
466
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200467 With :class:`PureWindowsPath`, return ``True`` if the path is considered
468 reserved under Windows, ``False`` otherwise. With :class:`PurePosixPath`,
469 ``False`` is always returned.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100470
471 >>> PureWindowsPath('nul').is_reserved()
472 True
473 >>> PurePosixPath('nul').is_reserved()
474 False
475
476 File system calls on reserved paths can fail mysteriously or have
477 unintended effects.
478
479
480.. method:: PurePath.joinpath(*other)
481
Andrew Kuchling7a4e2d12013-11-22 15:45:02 -0500482 Calling this method is equivalent to combining the path with each of
Antoine Pitrou31119e42013-11-22 17:38:12 +0100483 the *other* arguments in turn::
484
485 >>> PurePosixPath('/etc').joinpath('passwd')
486 PurePosixPath('/etc/passwd')
487 >>> PurePosixPath('/etc').joinpath(PurePosixPath('passwd'))
488 PurePosixPath('/etc/passwd')
489 >>> PurePosixPath('/etc').joinpath('init.d', 'apache2')
490 PurePosixPath('/etc/init.d/apache2')
491 >>> PureWindowsPath('c:').joinpath('/Program Files')
492 PureWindowsPath('c:/Program Files')
493
494
495.. method:: PurePath.match(pattern)
496
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200497 Match this path against the provided glob-style pattern. Return ``True``
498 if matching is successful, ``False`` otherwise.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100499
500 If *pattern* is relative, the path can be either relative or absolute,
501 and matching is done from the right::
502
503 >>> PurePath('a/b.py').match('*.py')
504 True
505 >>> PurePath('/a/b/c.py').match('b/*.py')
506 True
507 >>> PurePath('/a/b/c.py').match('a/*.py')
508 False
509
510 If *pattern* is absolute, the path must be absolute, and the whole path
511 must match::
512
513 >>> PurePath('/a.py').match('/*.py')
514 True
515 >>> PurePath('a/b.py').match('/*.py')
516 False
517
518 As with other methods, case-sensitivity is observed::
519
520 >>> PureWindowsPath('b.py').match('*.PY')
521 True
522
523
524.. method:: PurePath.relative_to(*other)
525
526 Compute a version of this path relative to the path represented by
527 *other*. If it's impossible, ValueError is raised::
528
529 >>> p = PurePosixPath('/etc/passwd')
530 >>> p.relative_to('/')
531 PurePosixPath('etc/passwd')
532 >>> p.relative_to('/etc')
533 PurePosixPath('passwd')
534 >>> p.relative_to('/usr')
535 Traceback (most recent call last):
536 File "<stdin>", line 1, in <module>
537 File "pathlib.py", line 694, in relative_to
538 .format(str(self), str(formatted)))
539 ValueError: '/etc/passwd' does not start with '/usr'
540
541
Larry Hastings3732ed22014-03-15 21:13:56 -0700542.. method:: PurePath.with_name(name)
543
544 Return a new path with the :attr:`name` changed. If the original path
545 doesn't have a name, ValueError is raised::
546
547 >>> p = PureWindowsPath('c:/Downloads/pathlib.tar.gz')
548 >>> p.with_name('setup.py')
549 PureWindowsPath('c:/Downloads/setup.py')
550 >>> p = PureWindowsPath('c:/')
551 >>> p.with_name('setup.py')
552 Traceback (most recent call last):
553 File "<stdin>", line 1, in <module>
554 File "/home/antoine/cpython/default/Lib/pathlib.py", line 751, in with_name
555 raise ValueError("%r has an empty name" % (self,))
556 ValueError: PureWindowsPath('c:/') has an empty name
557
558
559.. method:: PurePath.with_suffix(suffix)
560
561 Return a new path with the :attr:`suffix` changed. If the original path
562 doesn't have a suffix, the new *suffix* is appended instead::
563
564 >>> p = PureWindowsPath('c:/Downloads/pathlib.tar.gz')
565 >>> p.with_suffix('.bz2')
566 PureWindowsPath('c:/Downloads/pathlib.tar.bz2')
567 >>> p = PureWindowsPath('README')
568 >>> p.with_suffix('.txt')
569 PureWindowsPath('README.txt')
570
571
Antoine Pitrou31119e42013-11-22 17:38:12 +0100572.. _concrete-paths:
573
574
575Concrete paths
576--------------
577
578Concrete paths are subclasses of the pure path classes. In addition to
579operations provided by the latter, they also provide methods to do system
580calls on path objects. There are three ways to instantiate concrete paths:
581
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800582.. class:: Path(*pathsegments)
Antoine Pitrou31119e42013-11-22 17:38:12 +0100583
584 A subclass of :class:`PurePath`, this class represents concrete paths of
585 the system's path flavour (instantiating it creates either a
586 :class:`PosixPath` or a :class:`WindowsPath`)::
587
588 >>> Path('setup.py')
589 PosixPath('setup.py')
590
Eli Benderskyb6e66eb2013-11-28 06:53:05 -0800591 *pathsegments* is specified similarly to :class:`PurePath`.
592
593.. class:: PosixPath(*pathsegments)
594
595 A subclass of :class:`Path` and :class:`PurePosixPath`, this class
596 represents concrete non-Windows filesystem paths::
597
598 >>> PosixPath('/etc')
599 PosixPath('/etc')
600
601 *pathsegments* is specified similarly to :class:`PurePath`.
602
603.. class:: WindowsPath(*pathsegments)
604
605 A subclass of :class:`Path` and :class:`PureWindowsPath`, this class
606 represents concrete Windows filesystem paths::
607
608 >>> WindowsPath('c:/Program Files/')
609 WindowsPath('c:/Program Files')
610
611 *pathsegments* is specified similarly to :class:`PurePath`.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100612
613You can only instantiate the class flavour that corresponds to your system
614(allowing system calls on non-compatible path flavours could lead to
615bugs or failures in your application)::
616
617 >>> import os
618 >>> os.name
619 'posix'
620 >>> Path('setup.py')
621 PosixPath('setup.py')
622 >>> PosixPath('setup.py')
623 PosixPath('setup.py')
624 >>> WindowsPath('setup.py')
625 Traceback (most recent call last):
626 File "<stdin>", line 1, in <module>
627 File "pathlib.py", line 798, in __new__
628 % (cls.__name__,))
629 NotImplementedError: cannot instantiate 'WindowsPath' on your system
630
631
632Methods
633^^^^^^^
634
635Concrete paths provide the following methods in addition to pure paths
636methods. Many of these methods can raise an :exc:`OSError` if a system
637call fails (for example because the path doesn't exist):
638
639.. classmethod:: Path.cwd()
640
641 Return a new path object representing the current directory (as returned
642 by :func:`os.getcwd`)::
643
644 >>> Path.cwd()
645 PosixPath('/home/antoine/pathlib')
646
647
648.. method:: Path.stat()
649
650 Return information about this path (similarly to :func:`os.stat`).
651 The result is looked up at each call to this method.
652
653 >>> p = Path('setup.py')
654 >>> p.stat().st_size
655 956
656 >>> p.stat().st_mtime
657 1327883547.852554
658
659
660.. method:: Path.chmod(mode)
661
662 Change the file mode and permissions, like :func:`os.chmod`::
663
664 >>> p = Path('setup.py')
665 >>> p.stat().st_mode
666 33277
667 >>> p.chmod(0o444)
668 >>> p.stat().st_mode
669 33060
670
671
672.. method:: Path.exists()
673
674 Whether the path points to an existing file or directory::
675
676 >>> Path('.').exists()
677 True
678 >>> Path('setup.py').exists()
679 True
680 >>> Path('/etc').exists()
681 True
682 >>> Path('nonexistentfile').exists()
683 False
684
685 .. note::
686 If the path points to a symlink, :meth:`exists` returns whether the
687 symlink *points to* an existing file or directory.
688
689
690.. method:: Path.glob(pattern)
691
692 Glob the given *pattern* in the directory represented by this path,
693 yielding all matching files (of any kind)::
694
695 >>> sorted(Path('.').glob('*.py'))
696 [PosixPath('pathlib.py'), PosixPath('setup.py'), PosixPath('test_pathlib.py')]
697 >>> sorted(Path('.').glob('*/*.py'))
698 [PosixPath('docs/conf.py')]
699
700 The "``**``" pattern means "this directory and all subdirectories,
701 recursively". In other words, it enables recursive globbing::
702
703 >>> sorted(Path('.').glob('**/*.py'))
704 [PosixPath('build/lib/pathlib.py'),
705 PosixPath('docs/conf.py'),
706 PosixPath('pathlib.py'),
707 PosixPath('setup.py'),
708 PosixPath('test_pathlib.py')]
709
710 .. note::
711 Using the "``**``" pattern in large directory trees may consume
712 an inordinate amount of time.
713
714
715.. method:: Path.group()
716
Ned Deilyc0341562013-11-27 14:42:55 -0800717 Return the name of the group owning the file. :exc:`KeyError` is raised
Antoine Pitrou31119e42013-11-22 17:38:12 +0100718 if the file's gid isn't found in the system database.
719
720
721.. method:: Path.is_dir()
722
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200723 Return ``True`` if the path points to a directory (or a symbolic link
724 pointing to a directory), ``False`` if it points to another kind of file.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100725
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200726 ``False`` is also returned if the path doesn't exist or is a broken symlink;
Antoine Pitrou31119e42013-11-22 17:38:12 +0100727 other errors (such as permission errors) are propagated.
728
729
730.. method:: Path.is_file()
731
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200732 Return ``True`` if the path points to a regular file (or a symbolic link
733 pointing to a regular file), ``False`` if it points to another kind of file.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100734
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200735 ``False`` is also returned if the path doesn't exist or is a broken symlink;
Antoine Pitrou31119e42013-11-22 17:38:12 +0100736 other errors (such as permission errors) are propagated.
737
738
739.. method:: Path.is_symlink()
740
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200741 Return ``True`` if the path points to a symbolic link, ``False`` otherwise.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100742
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200743 ``False`` is also returned if the path doesn't exist; other errors (such
Antoine Pitrou31119e42013-11-22 17:38:12 +0100744 as permission errors) are propagated.
745
746
747.. method:: Path.is_socket()
748
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200749 Return ``True`` if the path points to a Unix socket (or a symbolic link
750 pointing to a Unix socket), ``False`` if it points to another kind of file.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100751
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200752 ``False`` is also returned if the path doesn't exist or is a broken symlink;
Antoine Pitrou31119e42013-11-22 17:38:12 +0100753 other errors (such as permission errors) are propagated.
754
755
756.. method:: Path.is_fifo()
757
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200758 Return ``True`` if the path points to a FIFO (or a symbolic link
759 pointing to a FIFO), ``False`` if it points to another kind of file.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100760
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200761 ``False`` is also returned if the path doesn't exist or is a broken symlink;
Antoine Pitrou31119e42013-11-22 17:38:12 +0100762 other errors (such as permission errors) are propagated.
763
764
765.. method:: Path.is_block_device()
766
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200767 Return ``True`` if the path points to a block device (or a symbolic link
768 pointing to a block device), ``False`` if it points to another kind of file.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100769
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200770 ``False`` is also returned if the path doesn't exist or is a broken symlink;
Antoine Pitrou31119e42013-11-22 17:38:12 +0100771 other errors (such as permission errors) are propagated.
772
773
774.. method:: Path.is_char_device()
775
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200776 Return ``True`` if the path points to a character device (or a symbolic link
777 pointing to a character device), ``False`` if it points to another kind of file.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100778
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200779 ``False`` is also returned if the path doesn't exist or is a broken symlink;
Antoine Pitrou31119e42013-11-22 17:38:12 +0100780 other errors (such as permission errors) are propagated.
781
782
783.. method:: Path.iterdir()
784
785 When the path points to a directory, yield path objects of the directory
786 contents::
787
788 >>> p = Path('docs')
789 >>> for child in p.iterdir(): child
790 ...
791 PosixPath('docs/conf.py')
792 PosixPath('docs/_templates')
793 PosixPath('docs/make.bat')
794 PosixPath('docs/index.rst')
795 PosixPath('docs/_build')
796 PosixPath('docs/_static')
797 PosixPath('docs/Makefile')
798
799.. method:: Path.lchmod(mode)
800
801 Like :meth:`Path.chmod` but, if the path points to a symbolic link, the
802 symbolic link's mode is changed rather than its target's.
803
804
805.. method:: Path.lstat()
806
807 Like :meth:`Path.stat` but, if the path points to a symbolic link, return
808 the symbolic link's information rather than its target's.
809
810
811.. method:: Path.mkdir(mode=0o777, parents=False)
812
813 Create a new directory at this given path. If *mode* is given, it is
814 combined with the process' ``umask`` value to determine the file mode
Antoine Pitrouf6abb702013-12-16 21:00:53 +0100815 and access flags. If the path already exists, :exc:`FileExistsError`
816 is raised.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100817
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200818 If *parents* is true, any missing parents of this path are created
Antoine Pitrou0048c982013-12-16 20:22:37 +0100819 as needed; they are created with the default permissions without taking
820 *mode* into account (mimicking the POSIX ``mkdir -p`` command).
821
822 If *parents* is false (the default), a missing parent raises
Antoine Pitrouf6abb702013-12-16 21:00:53 +0100823 :exc:`FileNotFoundError`.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100824
825
826.. method:: Path.open(mode='r', buffering=-1, encoding=None, errors=None, newline=None)
827
828 Open the file pointed to by the path, like the built-in :func:`open`
829 function does::
830
831 >>> p = Path('setup.py')
832 >>> with p.open() as f:
833 ... f.readline()
834 ...
835 '#!/usr/bin/env python3\n'
836
837
838.. method:: Path.owner()
839
Ned Deilyc0341562013-11-27 14:42:55 -0800840 Return the name of the user owning the file. :exc:`KeyError` is raised
Antoine Pitrou31119e42013-11-22 17:38:12 +0100841 if the file's uid isn't found in the system database.
842
843
844.. method:: Path.rename(target)
845
846 Rename this file or directory to the given *target*. *target* can be
847 either a string or another path object::
848
849 >>> p = Path('foo')
850 >>> p.open('w').write('some text')
851 9
852 >>> target = Path('bar')
853 >>> p.rename(target)
854 >>> target.open().read()
855 'some text'
856
857
858.. method:: Path.replace(target)
859
860 Rename this file or directory to the given *target*. If *target* points
861 to an existing file or directory, it will be unconditionally replaced.
862
863
864.. method:: Path.resolve()
865
866 Make the path absolute, resolving any symlinks. A new path object is
867 returned::
868
869 >>> p = Path()
870 >>> p
871 PosixPath('.')
872 >>> p.resolve()
873 PosixPath('/home/antoine/pathlib')
874
875 `".."` components are also eliminated (this is the only method to do so)::
876
877 >>> p = Path('docs/../setup.py')
878 >>> p.resolve()
879 PosixPath('/home/antoine/pathlib/setup.py')
880
881 If the path doesn't exist, :exc:`FileNotFoundError` is raised. If an
882 infinite loop is encountered along the resolution path,
883 :exc:`RuntimeError` is raised.
884
885
886.. method:: Path.rglob(pattern)
887
888 This is like calling :meth:`glob` with "``**``" added in front of the
889 given *pattern*:
890
891 >>> sorted(Path().rglob("*.py"))
892 [PosixPath('build/lib/pathlib.py'),
893 PosixPath('docs/conf.py'),
894 PosixPath('pathlib.py'),
895 PosixPath('setup.py'),
896 PosixPath('test_pathlib.py')]
897
898
899.. method:: Path.rmdir()
900
901 Remove this directory. The directory must be empty.
902
903
904.. method:: Path.symlink_to(target, target_is_directory=False)
905
906 Make this path a symbolic link to *target*. Under Windows,
Serhiy Storchaka03cc5652013-11-26 21:37:12 +0200907 *target_is_directory* must be true (default ``False``) if the link's target
Antoine Pitrou31119e42013-11-22 17:38:12 +0100908 is a directory. Under POSIX, *target_is_directory*'s value is ignored.
909
910 >>> p = Path('mylink')
911 >>> p.symlink_to('setup.py')
912 >>> p.resolve()
913 PosixPath('/home/antoine/pathlib/setup.py')
914 >>> p.stat().st_size
915 956
916 >>> p.lstat().st_size
917 8
918
919 .. note::
920 The order of arguments (link, target) is the reverse
921 of :func:`os.symlink`'s.
922
923
924.. method:: Path.touch(mode=0o777, exist_ok=True)
925
926 Create a file at this given path. If *mode* is given, it is combined
927 with the process' ``umask`` value to determine the file mode and access
928 flags. If the file already exists, the function succeeds if *exist_ok*
929 is true (and its modification time is updated to the current time),
Antoine Pitrouf6abb702013-12-16 21:00:53 +0100930 otherwise :exc:`FileExistsError` is raised.
Antoine Pitrou31119e42013-11-22 17:38:12 +0100931
932
933.. method:: Path.unlink()
934
935 Remove this file or symbolic link. If the path points to a directory,
936 use :func:`Path.rmdir` instead.