http://i2.xxx.com/wx/images_2016/monkey/m4_1e3thtr.png
如上url,需要匹配_1e3thtr这个自动加上的随机版本号(位数可能不固定),正则应该怎么写,因为前面的文件夹路径可能包含下划线,所以需要匹配最后的一个下划线
http://i2.xxx.com/wx/images_2016/monkey/m4_1e3thtr.png
如上url,需要匹配_1e3thtr这个自动加上的随机版本号(位数可能不固定),正则应该怎么写,因为前面的文件夹路径可能包含下划线,所以需要匹配最后的一个下划线
.*(_.*?)\.
第一步:“.*”,匹配到底;
第二步:括号里,“_”,回溯至最后一个下划线,接着“.*?”忽略优先,退出括号;
第三步:“\.”,如果没匹配到下划线后面的第一个点号,回溯到“.*?”,他匹配一个,退出括号,再看看后面是不是点号,如果不是,再回溯,然后匹配一个,看看后面是不是点号,......,最后匹配一个点号,结束。
然后“$1”获取结果。
正则不会。。。
var last_pos = url.lastIndexOf('_'),
sub_str1 = url.substr(0,last_pos),
sub_str2 = url.substring(last_pos+1),
sub_len1 = sub_str1.length - sub_str1.lastIndexOf('.') - 1,
sub_len2 = sub_str2.indexOf('.');
if(sub_len1>=sub_len2) {
url.substr(last_pos,sub_len2+1);
}else {
url.substr(last_pos-sub_len1,sub_len1+1);
}
我也有一个解法。
var s = 'http://i2.xxx.com/wx/images_2016/monkey/m4_1e3thtr.png';
var r = /(_[^_]*)\.[^.]+$/;
var m = s.match(r);
console.log(m[1]); // _1e3thtr
主要思路是从结尾开始,结尾是.xxx
形式,对应正则部分\.[^.]+$
;
从结尾往前(左),应该是_1e3thtr
形式的,对应的正则部分是(_[^_]*)
;
这里不用担心与前面的URL的下划线匹配到,因为限制了结尾,而且(_[^_]*)
这部分
只能匹配到_xxxxxdafasf
,_
开始,后续不是_
的字符串。
-END-
9 回答9.4k 阅读
6 回答5k 阅读✓ 已解决
5 回答3.6k 阅读✓ 已解决
4 回答8k 阅读✓ 已解决
7 回答10k 阅读
5 回答7.3k 阅读✓ 已解决
5 回答8.3k 阅读
用一个正向环视来确保匹配到最后一个下划线。