あなたのデスクトップは混沌としていますか?デスクトップやダウンロード ディレクトリにさまざまな種類のファイルが散らかっていませんか?簡単なスクリプトでこれを修正しましょう。
他の go プロジェクトの開始時に行うように、「go mod init」ディレクティブを使用して go.mod ファイルを生成します。物事を簡単にするために、すべてのロジックを main.go ファイルに記述します。
コードを書く前に、スクリプトをどのように動作させたいかについて少し話しましょう。ファイルの種類や作成日を示すディレクトリにファイルを整理できるようにしたいと考えています。つまり、スクリプトでビデオ ファイルをビデオ ディレクトリに、音楽ファイルを音楽ディレクトリなどに並べ替える必要があります。または、特定の日に作成されたすべてのファイルを同じディレクトリに並べ替えます。
それではコードを書いてみましょう:
main.go ファイルを作成し、次のように記述します:
package main type fileAnalyzer interface { analyzeAndSort() error } func analyze(fa fileAnalyzer) error { return fa.analyzeAndSort() }
プログラムでさまざまな基準でファイルを並べ替えたいため、analyzeAndSort メソッドを定義する fileAnalyzer インターフェイスを作成します。
次に、関数analyzeを作成します。この関数は、fileAnalyzerインターフェイスを実装する構造体を引数として受け取り、analyzeAndSortメソッドを実行します。
このプログラムで説明するような場合には、移動したくない特定のファイルが存在する可能性があります。たとえば、スクリプトのテスト中に、プログラムが go ファイルや実行可能ファイル/バイナリを別のディレクトリに移動することは望ましくありません。これを防ぐには、触れずに残したいすべてのファイルを含むブラックリストを作成する必要があります。
main.go ファイルに次のように記述します:
var blacklist = []string{ "go", "mod", "exe", "ps1", }
ここでは、並べ替えずに残しておきたいファイルの拡張子を追加しました。 「.go」と「.mod」は go ファイルの拡張子です。私は Windows マシンを使用しているため、バイナリの拡張子は「.exe」になります。ご覧のとおり、私は開発中に PowerShell スクリプトを使用するのが好きなので、「.ps1」も含めました。
次に、いくつかのヘルパー関数を作成します。
func getFileExtension(name string) string { return strings.TrimPrefix(filepath.Ext(name), ".") } func listFiles(dirname string) ([]string, error) { var files []string list, err := os.ReadDir(dirname) if err != nil { return nil, err } for _, file := range list { if !file.IsDir() { files = append(files, file.Name()) } } return files, nil } func listDirs(dirname string) ([]string, error) { var dirs []string list, err := os.ReadDir(dirname) if err != nil { return nil, err } for _, file := range list { if file.IsDir() { dirs = append(dirs, file.Name()) } } return dirs, nil } func mkdir(dirname string) error { err := os.Mkdir(dirname, 0644) if err != nil && os.IsExist(err) { return nil } var e *os.PathError if err != nil && errors.As(err, &e) { return nil } return err } func moveFile(name string, dst string) error { return os.Rename(name, filepath.Join(dst, name)) } func getCurrentDate(t time.Time) string { return t.Format("2006-01-02") } func filter[T any](ts []T, fn func(T) bool) []T { filtered := make([]T, 0) for i := range ts { if fn(ts[i]) { filtered = append(filtered, ts[i]) } } return filtered }
これらのほとんどは説明不要ですが、「mkdir」関数について説明したいと思います。 「mkdir」関数は、引数として渡された名前を使用してディレクトリを作成します。ただし、ディレクトリがすでに存在する場合、または「os.PathError」がある場合、この関数はエラーを返しません。
次に、fileAnalyzer インターフェイスを実装する構造体を作成しましょう。
package main type fileAnalyzer interface { analyzeAndSort() error } func analyze(fa fileAnalyzer) error { return fa.analyzeAndSort() }
fileTypeAnalyzer 構造体には、現在の作業ディレクトリの名前を保持する wd とマッパーの 2 つのプロパティがあります。マッパーのキーは検出されたファイルのタイプになり、その値はキーに関連付けられたファイル拡張子のリストになります。次に、コンストラクター関数を作成し、ファイル タイプとそれに関連するファイル拡張子をマッパーに提供します。自由にファイルの種類と拡張子をリストに追加してください。 anaylyzeAndSort メソッドは、ファイル拡張子をファイル タイプにマップし、ファイル タイプ ディレクトリを作成し、ファイルをそのディレクトリに移動するいくつかのヘルパー関数とメソッドを呼び出します。また、マッパーによってキャプチャされなかったファイルを保持する「misc」フォルダーも追加しました。もちろん、ブラックリストに登録されたファイルは除きます。
また、作成日ごとにファイルを整理できるようにしたいと考えています。 fileAnalyzer インターフェイスを実装し、ファイルを日付ごとに整理する別の構造体を作成しましょう。
var blacklist = []string{ "go", "mod", "exe", "ps1", }
ロジックの多くは fileTypeAnalyzer のロジックと同じです。主な違いは、マッパーを提供していないことです。代わりに、ファイル情報から作成日を取得し、それに応じてディレクトリを作成します。
次に、メイン関数にすべてをまとめてみましょう:
func getFileExtension(name string) string { return strings.TrimPrefix(filepath.Ext(name), ".") } func listFiles(dirname string) ([]string, error) { var files []string list, err := os.ReadDir(dirname) if err != nil { return nil, err } for _, file := range list { if !file.IsDir() { files = append(files, file.Name()) } } return files, nil } func listDirs(dirname string) ([]string, error) { var dirs []string list, err := os.ReadDir(dirname) if err != nil { return nil, err } for _, file := range list { if file.IsDir() { dirs = append(dirs, file.Name()) } } return dirs, nil } func mkdir(dirname string) error { err := os.Mkdir(dirname, 0644) if err != nil && os.IsExist(err) { return nil } var e *os.PathError if err != nil && errors.As(err, &e) { return nil } return err } func moveFile(name string, dst string) error { return os.Rename(name, filepath.Join(dst, name)) } func getCurrentDate(t time.Time) string { return t.Format("2006-01-02") } func filter[T any](ts []T, fn func(T) bool) []T { filtered := make([]T, 0) for i := range ts { if fn(ts[i]) { filtered = append(filtered, ts[i]) } } return filtered }
ロガーを設定します。 fileAnalyzer 実装に引数として渡す現在の作業ディレクトリを取得します。アプリケーションにフラグとして渡される値を保持するモード変数と、並べ替え方法を制御する switch ステートメントを作成します。最後に、analyze 関数を呼び出し、fileAnalyzer 実装を引数として渡します。
それだけです。バイナリをビルドしてテストしましょう。私は選別機に電話しました。 「go build -o [name]」
を使用して、好きな名前を付けることができます。これは、さまざまな種類のファイルが散在するフォルダーです:
ファイルの種類ごとに整理しましょう:
ファイル作成日順に整理しましょう:
おまけとして、Windows マシンを使用していて PowerShell を使用している場合に、プログラムのテストを簡単にするためのスクリプトを次に示します。
task.ps1 ファイルを作成し、次のように入力します:
type fileTypeAnalyzer struct { wd string mapper map[string][]string } func newFileTypeAnalyzer(wd string) *fileTypeAnalyzer { return &fileTypeAnalyzer{ wd: wd, mapper: map[string][]string{ "video": {"mp4", "mkv", "3gp", "wmv", "flv", "avi", "mpeg", "webm"}, "music": {"mp3", "aac", "wav", "flac"}, "images": {"jpg", "jpeg", "png", "gif", "svg", "tiff"}, "docs": {"docx", "csv", "txt", "xlsx"}, "books": {"pdf", "epub"}, }, } } func (f fileTypeAnalyzer) analyzeAndSort() error { files, err := listFiles(f.wd) if err != nil { return fmt.Errorf("could not list files: %w", err) } if err := f.createFileTypeDirs(files...); err != nil { return err } return f.moveFileToTypeDir(files...) } func (f fileTypeAnalyzer) moveFileToTypeDir(files ...string) error { dirs, err := listDirs(f.wd) if err != nil { return fmt.Errorf("could not list directories: %w", err) } for _, dir := range dirs { for _, file := range files { if slices.Contains(f.mapper[dir], strings.ToLower(getFileExtension(file))) { if err := moveFile(file, dir); err != nil { return err } } } } files, err = listFiles(f.wd) if err != nil { return err } if len(files) == 0 { return nil } files = filter(files, func(f string) bool { return !slices.Contains(blacklist, getFileExtension(f)) }) for i := range files { if err := f.moveToMisc(files[i]); err != nil { return err } } return nil } func (f fileTypeAnalyzer) moveToMisc(file string) error { if err := mkdir("misc"); err != nil { return err } return moveFile(file, "misc") } func (f fileTypeAnalyzer) createFileTypeDirs(files ...string) error { for ftype, fvalues := range f.mapper { for _, file := range files { if slices.Contains(fvalues, getFileExtension(file)) { if err := mkdir(ftype); err != nil { return fmt.Errorf("could not create folder: %w", err) } } } } return nil }
スクリプトを使用してバイナリをビルドするには:
スクリプトを使用してファイルを整理するには:
スクリプトを使用してディレクトリを削除するには:
以上がデスクトップを整理する: 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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

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