平常配置表中,经常需要用到时间配置,比如活动开始结束。从可读性上,我们喜欢2017-04-27 17:00:00,从程序角度,我们喜欢用1493283600。前者是包含时区概念的,而后者市区无关,所以一般推荐直接使用数字时间戳格式来配置。
实际配置时,之前一直用MySQL的FROM_UNIXTIME()和UNIX_TIMESTAMP函数,或者使用网页工具进行时间戳查看转换,还是十分繁琐的。突然想到为什么不直接写个插件,在编辑器里查看转换就好了。参考了网络上的一些示例并查阅了Sublime的相关API,过程如下。
依次执行Tools -> Developer -> New Plugin,新建一个插件脚本,命名为timestamp.py
脚本内容为以下代码代码,具体可以看注释:
```Python
from datetime import datetime
import re
import time
import sublime
import sublime_plugin
def getParseResult(text):
#patten1 匹配10位整数时间戳(1493283600)
pattern1 = re.compile('^\d{10}')
match1 = pattern1.match(text)
class TimestampCommand(sublime_plugin.TextCommand):
def run(self, edit):
for s in self.view.sel():
if s.empty() or s.size() <= 1:
break
```
进行快捷键绑定,依次执行Project -> Key Bindings,添加代码{ "keys": ["ctrl+t"], "command": "timestamp"}
很简单,一个能自动进行时间戳转换的Sublime Text3插件就好了,效果见下图: