0

0

[Go][Excelize] 确定单元格值是否有删除线

WBOY

WBOY

发布时间:2024-08-27 09:18:03

|

1138人浏览过

|

来源于dev.to

转载

简介

我想确定单元格的值是否有删除线。

[Go][Excelize] 确定单元格值是否有删除线

确定单元格的值是否有删除线

要确定单元格的值是否有删除线,我必须通过两种方式获取单元格样式。

Audo Studio
Audo Studio

AI音频清洗工具(噪音消除、声音平衡、音量调节)

下载

如果只有单元格的某些值被删除,如“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

资源

  • 单元格 - excelize 文档
  • xlsx/tutorial/tutorial.adoc - tealeg/xlsx - github

相关文章

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

106

2026.01.21

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

28

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

378

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

115

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

9

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.9万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号