幸福飞过海 - go https://fengqi.me/tag/go/ 我通过自制的Kodi命令行刮削器申请到了JetBrains的开源许可证 https://fengqi.me/go/632.html 2022-04-06T07:56:00+00:00 项目地址Kodi 刮削器命令行版本,使用TMDB数据源更早的起源2021年的双十一我在京东购买了索尼的X91J 65英寸版本,同时幸运的使用了那个2000的特殊优惠券,感谢京东没有回收这个羊毛。电视安装完成后,我开始着手构建自己的影音环境,在此之前,我是通过PT下载到NAS,然后电脑+2.0音箱播放,没有刮削,这之后我会转移到电视上来。索尼电视使用的是和当贝合作的Android系统国内特供版,不过也允许用户随意的安装第三方应用,我进行了大量的尝试,最后只保留了Bilibili、Kodi、SmartTubeNext、Netflix、Aptoide这几个应用。其中Kodi用来管理我从网络下载的电影和剧集,提供海报墙,观看进度跟踪,因为Kodi自带的刮削器不能满足我的需求,tinyMediaManager等半自动又太麻烦,所以我决定自制刮削器。[...] [记录]关于新增新字段sqlx报错missing destination name https://fengqi.me/go/629.html 2022-03-22T03:34:00+00:00 正常情况下,将数据的字段映射到一个struct的时候,需要使用db这个tag指定关系,典型的使用场景如下:type News struct { Id int64 `json:"id" db:"id"` GroupId int64 `json:"group_id" db:"group_id"` } news := &News{} err := db.QueryRowx("select...", x).StructScan(news)部分类库比如xorm会尝试根据驼峰、下划线去对应,sqlx并不会,而是会报panic级别的错误。查看源码,发现StructScan内部调用了scanAny这个方法,继续往下看,可以发现这样一段代码:fields := m.TraversalsByName(v.Type(), columns) // if we are not unsafe and are missing fields, return an error if f, err := missingFields(fields); err != nil && !r.unsafe { return fmt.Errorf("missing destination name %s in %T", columns[f], dest) }这里判断是否有字段缺失,同时有个unsafe开关,如果没有打开,就会报错,unsafe是在初始化db链接的时候指定的,可以通过调用db.Unsafe()方法返回一个打开unsafe开关的db实例,至于是全局使用还是每次调用时指定,看你自己了。PS: 如果愿意动动手,也可以通过db.Mapper = xx覆盖默认的Mapper方法,其中包括字段名映射逻辑,比如把xorm的逻辑移植过来。 正则表达式阶段性记录 https://fengqi.me/unix/608.html 2022-02-08T03:42:00+00:00 昨天在写一个diff脚本的时候,需要过滤#开头的注释,以及过滤掉过滤#后出现的空行,Google后我的脚本变成了grep -v '^#' | grep -v '^$' 这样,可用但是并太不明白^$的意思,猜测可能是开始即结束?因为我尝试加上几个空格匹配会失败,且改成 grep -v '^#'|grep -Ev '^\s+$' 是可以的,今天又搜了下想确认猜测,然而并没有找到相关的说明,但是也有其他收获。首先是梳理了下正则的各种分支和规范,比如POSIX、Perl、RE2等以及包含的子集。其次是匹配包括换行的写法,以前在写PHP的时候比较习惯使用flag,比如i、s、U这些,现在又多了几种写法:[\s\S]*、[\d\D]*、[\w\W]*、[\v\V]*、[\h\H]*。是不是挺迷惑,我一开始也是,那现在再来回顾下语法:\d 数字,[0-9] \D 非数字,[^0-9] \s 白空格,[\t\n\f\r ] \S 非白空格,[^\t\n\f\r ] \w 整个单词,[0-9A-Za-z_] \W 非整个单词,[^0-9A-Za-z_] \h 水平空格 \H 非水平空格 \v 垂直空格 \V 非垂直空格[...]