[Go][Excelize] セルの値に取り消し線があるかどうかを確認する
イントロ
セルの値に取り消し線があるかどうかを確認したいです。
セルの値に取り消し線があるかどうかを判断する
セルの値に取り消し線があるかどうかを判断するには、2 つの方法でセルのスタイルを取得する必要があります。
「A1」のようにセルの一部の値のみに取り消し線が引かれている場合は、「excelize.RichTextRun」からセルのスタイルを取得する必要があります。
「A2」のようにセル内のすべての値に取り消し線が付いている場合は、「excelize.xlsxXf」からセルのスタイルを取得する必要があります。
xlsxReader.go
package main import ( "fmt" "log" "github.com/xuri/excelize/v2" ) func GetCellStyles(filePath string) { xlFile, err := excelize.OpenFile(filePath) if err != nil { fmt.Println(err) } defer func() { // Close the spreadsheet. if err := xlFile.Close(); err != nil { fmt.Println(err) } }() sheetName := xlFile.GetSheetName(0) log.Println(sheetName) printCellStyles(xlFile, sheetName, "A1") printCellStyles(xlFile, sheetName, "A2") printCellStyles(xlFile, sheetName, "A3") } func printCellStyles(xlFile *excelize.File, sheetName string, cellAddress string) { log.Printf("--------%s--------", cellAddress) value, _ := xlFile.GetCellValue(sheetName, cellAddress) log.Println(value) // If the cell value has multiple formats, "GetCellRichText" will return multiple values. runs, _ := xlFile.GetCellRichText(sheetName, cellAddress) if len(runs) > 0 { for _, r := range runs { if r.Font == nil { log.Printf("Value: %s No fonts", r.Text) } else { log.Printf("Value: %s Strike through?: %t", r.Text, r.Font.Strike) } } } styleID, _ := xlFile.GetCellStyle(sheetName, cellAddress) // Get cell style info by styleID style := xlFile.Styles.CellXfs.Xf[styleID] // Get font info by style.FontID font := xlFile.Styles.Fonts.Font[*style.FontID] // Check if font.Strike != nil && *font.Strike.Val { log.Println("The cell value has a strike through") } else { log.Println("The cell value doesn't have a strike through") } }
結果
2024/08/27 03:02:32 Sheet1 2024/08/27 03:02:32 --------A1-------- 2024/08/27 03:02:32 123abc 2024/08/27 03:02:32 Value: 12 No fonts 2024/08/27 03:02:32 Value: 3ab Strike through?: true 2024/08/27 03:02:32 Value: c Strike through?: false 2024/08/27 03:02:32 The cell value doesn't have a strike through 2024/08/27 03:02:32 --------A2-------- 2024/08/27 03:02:32 aiu 2024/08/27 03:02:32 The cell value has a strike through 2024/08/27 03:02:32 --------A3-------- 2024/08/27 03:02:32 abc def ghi 2024/08/27 03:02:32 Value: abc No fonts 2024/08/27 03:02:32 Value: def Strike through?: false 2024/08/27 03:02:32 Value: Strike through?: false 2024/08/27 03:02:32 Value: ghi Strike through?: false 2024/08/27 03:02:32 The cell value doesn't have a strike through
リソース
- セル - ドキュメントをエクセル化
- xlsx/tutorial/tutorial.adoc - tealeg/xlsx - GitHub
以上が[Go][Excelize] セルの値に取り消し線があるかどうかを確認するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

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

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

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

オーディオとビデオ処理の中核は、基本的なプロセスと最適化方法を理解することにあります。 1.基本的なプロセスには、取得、エンコード、送信、デコード、再生が含まれ、各リンクには技術的な困難があります。 2。オーディオおよびビデオの異常、遅延、音のノイズ、ぼやけた画像などの一般的な問題は、同期調整、コーディング最適化、ノイズ減少モジュール、パラメーター調整などを通じて解決できます。 3. FFMPEG、OPENCV、WeBRTC、GSTREAMER、およびその他のツールを使用して機能を達成することをお勧めします。 4.パフォーマンス管理の観点から、ハードウェアの加速、解像度フレームレートの合理的な設定、並行性の制御、およびメモリの漏れの問題に注意を払う必要があります。これらの重要なポイントを習得すると、開発効率とユーザーエクスペリエンスの向上に役立ちます。

Kubernetesoperatorを書く最も効率的な方法は、Goを使用してKubeBuilderとController-Runtimeを組み合わせて使用することです。 1.オペレーターのパターンを理解する:CRDを介してカスタムリソースを定義し、コントローラーを作成してリソースの変更を聞き、和解ループを実行して予想される状態を維持します。 2。KubeBuilderを使用してプロジェクトを初期化し、APIを作成してCRD、コントローラー、構成ファイルを自動的に生成します。 3. API/V1/MyApp_Types.goでCRDの仕様とステータス構造を定義し、MakeManifestsを実行してCrdyamlを生成します。 4。コントローラーの和解

ApptlicationsInteractingingとfostresqlormysql、focusonindexing、selectivequeries、connectionhandling、caching、andormefficiency.1)使用プロペラインデックスの使用 - 識別のために識別を識別し、colulti-columnsを使用することを識別します

GOのHTTPログミドルウェアは、リクエストメソッド、パス、クライアントIP、および時間がかかることを記録できます。 1. http.handlerfuncを使用してプロセッサをラップします。2。next.servehttpを呼び出す前後の開始時間と終了時間を記録します。完全なサンプルコードの実行が検証されており、中小のプロジェクトの開始に適しています。拡張機能の提案には、ステータスコードのキャプチャ、JSONログのサポート、リクエストIDトラッキングが含まれます。

スタック割り当ては、明確なライフサイクルを備えた小さなローカル変数に適しており、速い速度で多くの制限で自動的に管理されます。ヒープ割り当ては、長期または不確実なライフサイクルのデータに使用され、柔軟性がありますが、パフォーマンスコストがあります。 GOコンパイラは、エスケープ分析を通じて変数割り当て位置を自動的に決定します。変数が現在の関数範囲から逃げる可能性がある場合、ヒープに割り当てられます。脱出を引き起こす一般的な状況には、ローカル変数ポインターの返却、インターフェイスタイプへの値の割り当て、ゴルチンの通過が含まれます。エスケープ分析の結果は、-gcflags = "-m"を介して表示できます。ポインターを使用する場合、不必要なエスケープを避けるために、可変ライフサイクルに注意を払う必要があります。

GO言語は科学的計算と数値分析に使用できますが、理解する必要があります。利点は、並行性のサポートとパフォーマンスにあります。これは、分散ソリューション、モンテカルロシミュレーションなどの並列アルゴリズムに適しています。 GonumやMAT64などのコミュニティライブラリは、基本的な数値計算関数を提供します。ハイブリッドプログラミングを使用して、CGOまたはインターフェイスを介してC/CとPythonを呼び出して実用性を向上させることができます。制限は、エコシステムがPythonほど成熟しておらず、視覚化と高度なツールは弱く、一部のライブラリ文書は不完全であることです。 GO機能に基づいて適切なシナリオを選択し、それらを詳細に使用するソースコードの例を参照することをお勧めします。

一般的なGO画像処理ライブラリには、イメージング、BIMG、Imagickなどの標準的なライブラリイメージパッケージとサードパーティライブラリが含まれます。 1.画像パッケージは、基本操作に適しています。 2。イメージングには完全な機能と単純なAPIがあり、ほとんどのニーズに適しています。 3. BIMGはLIBVIPに基づいており、パフォーマンスが強いため、大きな画像や高い並行性に適しています。 4。ImagicickはImageMagickをバインドします。これは強力ですが、重い依存関係を持っています。画像のスケーリングとトリミングをすばやく実装します。イメージングライブラリを使用して、COSSIZEおよびCROPANCHOR機能の数行のコードを介してそれを完了し、複数のパラメーター構成をサポートできます。フィルターの追加または調整トーンは、Grayscなどの想像力によって提供される色変換関数を通じて実現できます

パニックは、Goのプログラム「心臓発作」のようなものです。回復は、クラッシュを防ぐための「応急処置ツール」として使用できますが、回復は延期関数でのみ有効になります。 1.サービスの経過、ログログ、およびフレンドリーなエラーを返すために、回復が使用されます。 2. Deferと組み合わせて使用する必要があり、同じゴルウチンでのみ有効になります。プログラムは、回復後にパニックポイントに戻りません。 3.上位レベルまたは重要な入り口で使用し、悪用しないでください。エラー処理の使用を優先しないことをお勧めします。 4.一般的なパターンは、Saferun関数をカプセル化して、可能なパニックロジックをラップすることです。その使用シナリオと制限を習得することによってのみ、その役割を果たすことができます。
