基于Python實現(xiàn)文件大小輸出
在數(shù)據(jù)庫中存儲時,使用 Bytes 更精確,可擴展性和靈活性都很高。
輸出時,需要做一些適配。
1. 注意事項與測試代碼
1.需要考慮 sizeInBytes 為 None 的場景。
2.除以 1024.0 而非 1024,避免丟失精度。
實現(xiàn)的函數(shù)為 getSizeInMb(sizeInBytes),通用的測試代碼為
def getSizeInMb(sizeInBytes): return 0 def test(sizeInBytes): print '%s -> %s' % (sizeInBytes, getSizeInMb(sizeInBytes)) test(None) test(0) test(10240000) test(1024*1024*10)
2. 以 MB 為單位輸出 -- 返回 float
通常,電子書的大小在 1 - 50MB 之間,輸出時統(tǒng)一轉(zhuǎn)為 MB 是不錯的選擇。
弊端:
1.輸出精度過高,比如 10240000 Bytes 計算結(jié)果為 10240000 -> 9.765625
2.文件大小有限制,小于 1 MB 或 G 級數(shù)據(jù)不適合該方式展示
優(yōu)勢:
1.適合于用返回值參與計算
def getSizeInMb(sizeInBytes): return (sizeInBytes or 0) / (1024.0*1024.0)
3. 以 MB 為單位保留 1 位小數(shù) -- 返回 str
處于精度問題考慮,可以選擇保留 1 位小數(shù)。
def getSizeInMb(sizeInBytes):
return '%.1f' % ((sizeInBytes or 0) / (1024.0*1024.0), ) # use 1-dimension tuple is suggested
返回值建議寫成 '%.1f' % (number,) 而非 '%.1f' % (number)
二者均能正確執(zhí)行,但后者容易被誤判為執(zhí)行只有一個參數(shù) number 的函數(shù),導致難以判斷的錯誤。
3. 以 MB 為單位保留至多 1 位小數(shù) -- 返回 str
大多數(shù)操作系統(tǒng)一般展示至多 1 位小數(shù)
def getSizeInMb(sizeInBytes): sizeInMb = '%.1f' % ((sizeInBytes or 0) / (1024.0*1024.0), ) # use 1-dimension tuple is suggested return sizeInMb[:-2] if sizeInMb.endswith('.0') else sizeInMb # python2.5+ required
4. 自動選擇最佳單位
def getSizeInNiceString(sizeInBytes): """ Convert the given byteCount into a string like: 9.9bytes/KB/MB/GB """ for (cutoff, label) in [(1024*1024*1024, "GB"), (1024*1024, "MB"), (1024, "KB"), ]: if sizeInBytes >= cutoff: return "%.1f %s" % (sizeInBytes * 1.0 / cutoff, label) if sizeInBytes == 1: return "1 byte" else: bytes = "%.1f" % (sizeInBytes or 0,) return (bytes[:-2] if bytes.endswith('.0') else bytes) + ' bytes'
算法說明:
1. 從英語語法角度,只有 1 使用單數(shù)形式。其他 0/小數(shù) 均使用復(fù)數(shù)形式。涉及 bytes 級別
2. 精度方面,KB 及以上級別,保留 1 位小數(shù)。bytes 保留至多 1 位小數(shù)。
這種處理規(guī)則,不適合于小數(shù)十分位為 0 的情況,比如 10.0 bytes,10.01 bytes。輸入結(jié)果均為 10 bytes。
其他情況下,精度均不存在問題。
測試數(shù)據(jù)與結(jié)果如下圖
以上內(nèi)容給大家介紹了基于Python實現(xiàn)文件大小輸出的相關(guān)知識,希望本文分享對大家有所幫助。
相關(guān)文章
Python Pandas 轉(zhuǎn)換unix時間戳方式
今天小編就為大家分享一篇Python Pandas 轉(zhuǎn)換unix時間戳方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12Python+OpenCV實戰(zhàn)之拖拽虛擬方塊的實現(xiàn)
這篇文章主要介紹了如何利用Python+OpenCV實現(xiàn)拖拽虛擬方塊的效果,即根據(jù)手指坐標位置和矩形的坐標位置,判斷手指點是否在矩形上,如果在則矩形跟隨手指移動,感興趣的可以了解一下2022-08-08Python從入門到實戰(zhàn)之數(shù)據(jù)結(jié)構(gòu)篇
數(shù)據(jù)結(jié)構(gòu)中有很多樹的結(jié)構(gòu),其中包括二叉樹、二叉搜索樹、2-3樹、紅黑樹等等。本文中對數(shù)據(jù)結(jié)構(gòu)進行了總結(jié),不求嚴格精準,但求簡單易懂2021-11-11python使用正則表達式(Regular Expression)方法超詳細
這篇文章主要介紹了python使用正則表達式(Regular Expression)方法超詳細,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12Python利用裝飾器click處理解析命令行參數(shù)
這篇文章主要為大家詳細介紹了Python如何利用裝飾器click實現(xiàn)處理解析命令行參數(shù)功能,文中的示例代碼簡潔易懂,需要的小伙伴快跟隨小編一起了解一下2022-10-10在Linux系統(tǒng)上安裝Python的Scrapy框架的教程
這篇文章主要介紹了在Linux系統(tǒng)上安裝Python的Scrapy框架的教程,Scrapy是著名的專門針對搜索引擎的爬蟲制作而研發(fā)的Python框架,需要的朋友可以參考下2015-06-06