File Browser
Task
The ls
command is a powerful file viewing command in Linux.
Please implement a similar command-line tool in Python. It should support the following command-line options:
-a
or--all
: Include hidden files in the file list.-w
or--human-readable
: Display file sizes in a human-readable format.-h
or--help
: Display help information.
Python implementation
ls.py
import os
import argparse
import sys
def ls(directory='.', show_hidden=False, human_readable=False):
file_list = os.listdir(directory)
file_list.sort()
if not show_hidden:
file_list = [f for f in file_list if not f.startswith('.')]
if human_readable:
file_list = [(f, get_human_readable_size(os.path.join(directory, f))) for f in file_list]
for file, size in file_list:
print(f"{file}\t{size}")
else:
for file in file_list:
print(file)
def get_human_readable_size(file_path):
size = os.path.getsize(file_path)
units = ['B', 'KB', 'MB', 'GB', 'TB']
index = 0
while size >= 1024 and index < len(units) - 1:
size /= 1024
index += 1
return f"{size:.2f} {units[index]}"
def main():
parser = argparse.ArgumentParser(description='List files in a directory.')
parser.add_argument('-a', '--all', action='store_true', help='Include hidden files')
parser.add_argument('-w', '--human-readable', action='store_true', help='Display file sizes in human-readable format')
args = parser.parse_args()
ls(directory='.', show_hidden=args.all, human_readable=args.human_readable)
if __name__ == '__main__':
main()
What is __main__?
In Python, each .py file is a Python module. Except for the application entry module, other modules usually cannot be run directly. However, for convenience of testing, the following code is often written to provide a testing interface for the module:
if __name__ == '__main__':
main()
This means that when running the script directly using the Python command, the code in the main
function will be executed. When the script is imported as a module by other modules, the main
function will not be executed.
Testing
List files
python ls.py
Display file sizes in a human-readable format
python ls.py -w
Display all files
python ls.py -a
Combine options
python ls.py -aw