ホームページ バックエンド開発 Golang [Go][Excelize] セルの値に取り消し線があるかどうかを確認する

[Go][Excelize] セルの値に取り消し線があるかどうかを確認する

Aug 27, 2024 am 06:36 AM

イントロ

セルの値に取り消し線があるかどうかを確認したいです。

[Go][Excelize] Determining if a cell

セルの値に取り消し線があるかどうかを判断する

セルの値に取り消し線があるかどうかを判断するには、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 サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

ホットトピック

オーディオ/ビデオ処理に移動します オーディオ/ビデオ処理に移動します Jul 20, 2025 am 04:14 AM

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

GoでKubernetesオペレーターの開発 GoでKubernetesオペレーターの開発 Jul 25, 2025 am 02:38 AM

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

PostgreSQL/MySQLのクエリ最適化テクニックに移動します PostgreSQL/MySQLのクエリ最適化テクニックに移動します Jul 19, 2025 am 03:56 AM

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

HTTPミドルウェアロギングの例を例に進めます HTTPミドルウェアロギングの例を例に進めます Aug 03, 2025 am 11:35 AM

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

GOのポインターを備えたスタックvsヒープ割り当て GOのポインターを備えたスタックvsヒープ割り当て Jul 23, 2025 am 04:14 AM

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

科学的なコンピューティングと数値分析に進みます 科学的なコンピューティングと数値分析に進みます Jul 23, 2025 am 01:53 AM

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

画像操作ライブラリに移動します 画像操作ライブラリに移動します Jul 21, 2025 am 12:23 AM

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

Goのパニックから回復する方法は? Goのパニックから回復する方法は? Jul 23, 2025 am 04:11 AM

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

See all articles