관리-도구
편집 파일: filesize.cpython-311.pyc
� P�Dgz � �2 � d Z ddlmZ dddd�Z ddd�ZdS )z$Bits and bytes related humanization.� )�annotations)z kBz MBz GBz TBz PBz EBz ZBz YB)z KiBz MiBz GiBz TiBz PiBz EiBz ZiBz YiB�KMGTPEZY)�decimal�binary�gnuF�%.1f�value�float | strr �boolr �format�str�returnc �` � |rt d }n|rt d }n t d }|s|rdnd}t | � � }t |� � }|dk r|sd|z S ||k r|sd|z S ||k r|rd |z S t |� � D ]\ }} ||d z z } || k r n�|||z | z z | z }|S )aP Format a number of bytes like a human readable filesize (e.g. 10 kB). By default, decimal suffixes (kB, MB) are used. Non-GNU modes are compatible with jinja2's `filesizeformat` filter. Examples: ```pycon >>> naturalsize(3000000) '3.0 MB' >>> naturalsize(300, False, True) '300B' >>> naturalsize(3000, False, True) '2.9K' >>> naturalsize(3000, False, True, "%.3f") '2.930K' >>> naturalsize(3000, True) '2.9 KiB' >>> naturalsize(10**28) '10000.0 YB' >>> naturalsize(-4096, True) '-4.0 KiB' ``` Args: value (int, float, str): Integer to convert. binary (bool): If `True`, uses binary suffixes (KiB, MiB) with base 2<sup>10</sup> instead of 10<sup>3</sup>. gnu (bool): If `True`, the binary argument is ignored and GNU-style (`ls -sh` style) prefixes are used (K, M) with the 2**10 definition. format (str): Custom formatter. Returns: str: Human readable representation of a filesize. r r r i i� � z%d Bytez%d Bytesz%dB� )�suffixes�float�abs� enumerate)r r r r �suffix�base�bytes_� abs_bytes�i�s�unit�rets �q/builddir/build/BUILD/imunify360-venv-2.4.0/opt/imunify360/venv/lib/python3.11/site-packages/humanize/filesize.py�naturalsizer s � �T � %��%���� � %��(�#����)�$���,�6�,�4�4��D� �5�\�\�F��F���I��A�~�~�c�~��6�!�!��4������F�"�"��4���C���v�~���&�!�!� � ���1���A�����t����E� � �����-�.��2�C��J� N)FFr ) r r r r r r r r r r )�__doc__� __future__r r r � r r �<module>r$ sl �� +� *� "� "� "� "� "� "� H�N��� �� ��� E� E� E� E� E� E� Er