| % By Skip Montanaro |
| |
| \section{Standard Module \sectcode{stat}} |
| \stmodindex{stat} |
| \label{module-stat} |
| |
| The \code{stat} module defines constants and functions for interpreting the |
| results of \code{os.stat()} and \code{os.lstat()} (if they exist). |
| For complete details about the \code{stat()} and \code{lstat()} system |
| calls, consult your local man pages. |
| |
| The \code{stat} module defines the following functions: |
| |
| \setindexsubitem{(in module stat)} |
| |
| \begin{funcdesc}{S_ISDIR}{mode} |
| Return non-zero if the mode was gotten from a directory. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{S_ISCHR}{mode} |
| Return non-zero if the mode was gotten from a character special device. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{S_ISBLK}{mode} |
| Return non-zero if the mode was gotten from a block special device. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{S_ISREG}{mode} |
| Return non-zero if the mode was gotten from a regular file. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{S_ISFIFO}{mode} |
| Return non-zero if the mode was gotten from a FIFO. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{S_ISLNK}{mode} |
| Return non-zero if the mode was gotten from a symbolic link. |
| \end{funcdesc} |
| |
| \begin{funcdesc}{S_ISSOCK}{mode} |
| Return non-zero if the mode was gotten from a socket. |
| \end{funcdesc} |
| |
| All the data items below are simply symbolic indexes into the 10-tuple |
| returned by \code{os.stat()} or \code{os.lstat()}. |
| |
| \begin{datadesc}{ST_MODE} |
| Inode protection mode. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_INO} |
| Inode number. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_DEV} |
| Device inode resides on. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_NLINK} |
| Number of links to the inode. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_UID} |
| User id of the owner. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_GID} |
| Group id of the owner. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_SIZE} |
| File size in bytes. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_ATIME} |
| Time of last access. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_MTIME} |
| Time of last modification. |
| \end{datadesc} |
| |
| \begin{datadesc}{ST_CTIME} |
| Time of creation. |
| \end{datadesc} |
| |
| Example: |
| |
| \begin{verbatim} |
| import os, sys |
| from stat import * |
| |
| def process(dir, func): |
| '''recursively descend the directory rooted at dir, calling func for |
| each regular file''' |
| |
| for f in os.listdir(dir): |
| mode = os.stat('%s/%s' % (dir, f))[ST_MODE] |
| if S_ISDIR(mode): |
| # recurse into directory |
| process('%s/%s' % (dir, f), func) |
| elif S_ISREG(mode): |
| func('%s/%s' % (dir, f)) |
| else: |
| print 'Skipping %s/%s' % (dir, f) |
| |
| def f(file): |
| print 'frobbed', file |
| |
| if __name__ == '__main__': process(sys.argv[1], f) |
| \end{verbatim} |