ファイルでもフォルダーでも、ディレクトリ内のすべての項目をサイズの降順に並べ替える単純なプログラムです。
オペレーティング システムはディレクトリを参照するときにディレクトリの内容の合計サイズを計算しないため、グラフィカル ファイル ブラウザを使用しているかコマンド ラインを使用しているかにかかわらず、ディレクトリ内の項目をサイズの降順で並べ替えるのは、思っているほど簡単ではありません。木。この記事では、ほとんどのオペレーティング システムでこの問題を解決する完全な動作プログラムを提供します。
問題
おそらく次のようなおなじみのものを見つけるでしょう:
仕事であれ、個人的なプロジェクトであれ、私は親ディレクトリ (たとえば Projects というディレクトリ) を作成し、そこに個々のプロジェクトのすべてのコンテンツを保存することで、デジタル アセットを整理するのが好きです。プロジェクトが小さく、多くのコンテンツが含まれていない場合は、単一のファイル (通常はテキスト ファイル) を使用します。プロジェクトにさらに多くのコンテンツ (テキスト ファイルやいくつかのスクリーンショットなど) が含まれる場合は、そのプロジェクト用のフォルダーを作成し、そこに関連するすべてのアセットを配置します。したがって、私の観点からすると、単一のテキスト ファイルとフォルダーは、それぞれがプロジェクトを表すという意味で同等です。唯一の違いは、フォルダーがより大きなプロジェクトを表し、より多くのものを含むことです。
時々、自分のプロジェクトのうちどれが現在最大で、どれが最も多くのものを含んでいるかを確認したいことがあります。これは通常、特定の分野にしばらく取り組んでいないために発生します。そのため、その分野に戻ったときに、どのプロジェクトに最も多くのコンテンツが含まれているかを確認したいと考えます。私の推論は、最も多くのコンテンツを含むプロジェクトが最も完成度が高いはずであり、したがって、おそらくそれが最も簡単に完了するので、最初に作業を開始する必要があるということです。
たとえば、次の内容を含むディレクトリについて考えてみましょう:
Name | Type | Size |
---|---|---|
Huge Project.txt | File | 2.6KB |
Larger Project | Folder | 1.07KB |
0 - Tiny Project | Folder | 0KB |
Basic Project.txt | File | 0.36KB |
Big Project.txt | File | 2.11KB |
上記のディレクトリをサイズの降順で並べ替えると、次のように出力されます。
Huge Project.txt 2.6KB Big Project.txt 2.11KB Larger Project 1.07KB Basic Project.txt 0.36KB 0 - Tiny Project 0KB
ただし、これは、Windows、Mac、Linux のグラフィカル ファイル ブラウザで [サイズ] 列ヘッダーをクリックしたときに表示されるものではありません。
窓
マック
Linux
コマンド ラインを使用すると、目的の出力に多少近い出力が得られますが、完全に正しいわけではありません。
窓
ディレクトリ /b /o:-d
出力:
Larger Project 0 - Tiny Project Huge Project.txt Big Project.txt Basic Project.txt
MacとLinux
Mac や Linux などの UNIX ベースのシステムでは、ディレクトリの内容を並べ替えるためのさまざまなコマンドの組み合わせがあります。ほとんどの場合、du、sort、ls の使用が必要になります。オンラインで見つけた他の例では、find と grep も同様に混合しました。
私が試したものは次のとおりです:
デュ |選別
du -a -h --max- Depth=1 |並べ替え -hr
出力:
32K . 8.0K ./Larger Project 8.0K ./0 - Tiny Project 4.0K ./Huge Project.txt 4.0K ./Big Project.txt 4.0K ./Basic Project.txt
ls
ls コマンドで -S スイッチを使用すると、まさに私が探していること、つまり項目をサイズの降順で並べ替えることができるはずです。
ls -S
出力:
'0 - Tiny Project' 'Larger Project' 'Huge Project.txt' 'A - Big Project.txt' 'Basic Project.txt'
出力はオフのままです。 -l (長い) スイッチを追加してみました。
ls -ls
出力:
total 20 drwx---r-x 2 admin admin 4096 Sep 20 21:49 '0 - Tiny Project' drwx---r-x 2 admin admin 4096 Sep 20 21:49 'Larger Project' -rw-rw-r-- 1 admin admin 2667 Sep 20 21:49 'Huge Project.txt' -rw-rw-r-- 1 admin admin 2164 Sep 20 21:49 'Big Project.txt' -rw-rw-r-- 1 admin admin 368 Sep 20 21:49 'Basic Project.txt'
予想どおり、出力にはより詳細な情報が含まれていますが、並べ替え順序は以前と同じです。
根本的な原因
さまざまなコマンドの出力では望ましい結果が得られませんが、問題の根本原因が明らかになります。ディレクトリ ツリーを参照するとき、オペレーティング システムは、フォルダを再帰してコンテンツの合計サイズを計算しません。代わりに、すべてのフォルダーが同じ固定サイズを持つものとして扱われます。通常、これはファイル システムの最小ブロック サイズで、通常は 4096 バイト、4KB です。
解決
この問題を解決する無料ツールは少なくとも十数個はあるはずですが、正直に言うと、私は調べもしませんでした。同じことを行うスクリプト/プログラムを書いてここで共有するほうが簡単で、肥大化も少なく、できれば他の人にも役立ち、間違いなくもっと楽しいと感じました。
もう十分長く悩んでしまいました。コードは次のとおりです:
パイソン
Huge Project.txt 2.6KB Big Project.txt 2.11KB Larger Project 1.07KB Basic Project.txt 0.36KB 0 - Tiny Project 0KB
パワーシェル
Larger Project 0 - Tiny Project Huge Project.txt Big Project.txt Basic Project.txt
Cシャープ
32K . 8.0K ./Larger Project 8.0K ./0 - Tiny Project 4.0K ./Huge Project.txt 4.0K ./Big Project.txt 4.0K ./Basic Project.txt
行く
'0 - Tiny Project' 'Larger Project' 'Huge Project.txt' 'A - Big Project.txt' 'Basic Project.txt'
4 つの実装にはいくつかの小さな違いがありますが、4 つすべてで使用される一般的なアプローチは同じです。
- 項目 (ファイルまたはフォルダー) の名前とサイズのキーと値のペアのコレクションを返す再帰関数を作成します。
- メイン関数またはブロックで、基本的な入力検証を実行し、ユーザーが有効なパスを指定した場合は、そのパスで再帰関数を実行します。
- 再帰関数の出力を値 (サイズ) で降順に並べ替えます。
- ソートされた出力をコンソールに出力します。出力される各行は形式に従います。項目名、タブ文字、項目サイズを 1024 で割って小数点第 2 位に四捨五入してキロバイト単位のサイズを取得し、その後にサイズ単位を示す「KB」が続きます。
使用法
コマンドラインで、ソートするディレクトリへのパスを最初のパラメータとして渡します。考えられるすべての例をリストするわけではありませんが、コードをコピーし、「ディレクトリ降順」の略称である dir_desc というファイル名と適切なファイル拡張子を付けて保存したものとして、いくつかの例を示します。
Mac または Linux での Python の使用:
python3 dir_desc.py
Windows での PowerShell の使用:
powershell -f dir_desc.ps1
言語と実装の違い
- Python と Go は、最初のコマンド ライン引数が args 配列の 2 番目の項目であるという点で、C やその他の C に似た言語に似ています。 .NET 言語、PowerShell および C# では、最初の引数は args 配列の最初の項目です。
- PowerShell では、組み込みの Get-ChildItem (gci) および Measure-Object (measure) コマンドレットを使用すると、目的の結果をより簡単に実現できるため、別の再帰関数を作成する必要はありません。
- Go では、キーと値のペア (マップ) のコレクションを値で並べ替えるには、他の言語よりも数行多くのコードが必要になります。これは、組み込みの並べ替え関数がマップではなく配列/スライスを操作するように設計されているためです。
- Go では、浮動小数点数を小数点以下 X 桁に丸める処理は、数値を四捨五入する場合とは対照的に、fmt.Printf() 関数を使用して出力を印刷するときに処理されます。ちなみに、これは数学を使用せずに実行できます。 .Round() 関数。 C のバックグラウンドがある場合、これはおそらく直感的に理解できるでしょう。残りの人にとって、これは少し奇妙ですが、問題なく機能します。
私は Python でのオリジナルのアプローチを他のいくつかの言語に移植しました。その結果、3 つの主要なオペレーティング システムのそれぞれで少なくとも 1 つのバージョンが動作するはずです。
- Mac および Linux: デフォルトで python3 インタープリターがインストールされている必要があります。そうでない場合は、Go バージョンを使用できます。一部の Linux システムには、Go をコンパイルできるバージョンの gcc がデフォルトでインストールされている場合がありますが、ほとんどのシステムはそうではないため、Go コンパイラーをダウンロードする必要があります。
- Windows: PowerShell バージョンは、Windows 10 以降のシステムでそのまま動作します。古いシステムの場合は、おそらく C# バージョンの方が良い選択です。 Windows の組み込み C# コンパイラを使用してコードをコンパイルできます。
それで終わりです。もう一匹のヤクは毛を剃った。これがお役に立てば幸いです。
以上がPython、PowerShell、C#、または Go を使用してディレクトリ内のアイテムをサイズの降順で並べ替えるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

GO言語で文字列パッケージをマスターすると、テキスト処理機能と開発効率が向上します。 1)コンテナ機能を使用してサブストリングを確認し、2)インデックス関数を使用してサブストリング位置を見つけ、3)関数を効率的にスプライスストリングスライス、4)機能を置き換えてサブストリングを置き換えます。空の文字列や大きな文字列操作のパフォーマンスの問題をチェックしないなど、一般的なエラーを避けるように注意してください。

文字列の操作を簡素化し、コードをより明確かつ効率的にすることができるため、GOの文字列パッケージを気にする必要があります。 1)文字列を使用して、弦を効率的にスプライスするために参加します。 2)文字列を使用して、空白の文字で文字列を分割します。 3)文字列を介してサブストリング位置を見つけます。Indexと文字列lastindex; 4)文字列を使用して、文字列を置き換える。 5)文字列を使用して、ビルダーを効率的にスプライスします。 6)予期しない結果を避けるために、常に入力を確認してください。

theStringspackageIngoisESSENTINEFOREFFSTRINGMANIPULATION.1)ITOFFERSSSIMPLEYETPOWERFULFUNCTIONS FORTOSSCHECKINGSUBSTRINGSNINGSTRINGS.2)ITHANDLESUNICODEWELL、ITHANDLESUNICODEWELL

whendeciding botedego'sbytespackageandstringspackage、usebytes.bufferbinarydataandstrings.builderforstringoperations.1)usebytes.bufferforkithbyteslices、binarydata、appendingdatatypes、およびwritioio.writioio.writioio.writioio.writioio.

Goの文字列パッケージは、さまざまな文字列操作機能を提供します。 1)文字列を使用して、サブストリングを確認します。 2)文字列を使用して、ストリングをサブストリングスライスに分割します。 3)文字列を通して文字列をマージします。 4)文字列または文字列を使用して、文字列の最初と端でブランクまたは指定された文字を削除します。 5)指定されたすべてのサブストリングを文字列に置き換えます。ReplaceAll。 6)文字列を使用して、hasprefixまたは文字列hassuffixを使用して、文字列の接頭辞または接尾辞を確認します。

GO言語文字列パッケージを使用すると、コードの品質が向上します。 1)文字列を使用して()join()を使用して、パフォーマンスのオーバーヘッドを避けるために、文字列アレイをエレガントに接続します。 2)strings.split()とstrings.contains()を組み合わせて、テキストを処理し、ケースの感度の問題に注意を払います。 3)文字列の乱用を避け、replace()を回避し、多数の置換に正規表現を使用することを検討します。 4)文字列を使用して、ビルダーを使用して、頻繁にスプライシング文字列の性能を向上させます。

GoのBYTESパッケージは、バイトスライスを処理するためのさまざまな実用的な機能を提供します。 1.bites.containsは、バイトスライスに特定のシーケンスが含まれているかどうかを確認するために使用されます。 2.bites.splitは、バイトスライスをスモールピースに分割するために使用されます。 3.bites.joinは、複数のバイトスライスを1つに連結するために使用されます。 4.bites.trimspaceは、バイトスライスのフロントブランクとバックブランクを削除するために使用されます。 5.バイト。エクアルは、2つのバイトスライスが等しいかどうかを比較するために使用されます。 6.bytes.indexは、大規模なスライスでサブスライスの開始インデックスを見つけるために使用されます。

エンコード/binaryPackageIngoisESSENTINESTENTINESTINESTIDANDARDIZEDWAIDTOREADANDWRITEBINIRYDATA、クロスプラットフォームコンパティビティアンドハンドリングの可能性を確保することを確認します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
