Java如何高效地截取带有汉字的字符串中的时间信息?

发布于 2022-09-01 06:55:44 字数 213 浏览 11 评论 0

字符串同时有三种格式,如下,需要获取字符串中的时间,即2015-05-01 21:35,16小时,15分钟
"文章由xxx 于2015-05-01 21:35分享"
"文章由xxx 于16小时前分享"
"文章由xxx 于15分钟前分享"
注:xxx为用户名

用什么方式可以比较高效地截取时间信息?

我知道正则君强大,能提供详细思路就更好了。。。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

流星番茄 2022-09-08 06:55:44

如果只有这三种的话: (\d{4}-\d{2}-\d{2} \d{2}:\d{2})|(\d{1,2}小时)|(\d{1,2}分钟)

想你的星星会说话 2022-09-08 06:55:44

Java 没怎么碰过,给个思路吧,首先正则直接匹配 /于(.+?)分享/g,获取到时间字符串,直接 Date 化看是否成功,如果成功则获取到了没成功则是词义化的时间,自己写一个函数根据当前时间推断词义化时间的具体时间。

猫性小仙女 2022-09-08 06:55:44

正则表达式(逃

笨笨の傻瓜 2022-09-08 06:55:44

补充答案:
String str="文章由xxx 于2015-05-01 21:35分享";
方法一:(简单粗暴)

int start=str.lastIndexOf("于");
int end=str.lastIndexOf("分享");
String result=str.substring(start+1,end);

方法二:(正则)

String regEx="(\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2})|(\\d{1,2}小时)|(\\d{1,2}分钟)";
Pattern p = Pattern.compile(regEx);
Matcher m = p.matcher(str);
if(m.find()){
    String result=m.group();
}

注:常规法,不能处理掉“前”字;Java的正则表达式单斜杠变为双斜杠,否则会报错Invalid escape sequence

ㄖ落Θ余辉 2022-09-08 06:55:44

用正则表达式。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文