- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Oracle 正则表达式实例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Oracle 正则表达式实例详解 。
FORM开发中的按行拆分需求:拆分后的行要有规律,并按前后层次排序 。
需求分析如下:
现有行: 2 , 2.1 , 2.2 , 2.3 3 2.1.1, 2.1.2 , 2.1.3 , 2.2.1 , 2.1.1.1, 2.1.1.2, 。
对 2 进行拆分得到的 结果应该是 2.4 (2.4 是通过 查看历史记录中以2 开头,有一位小数点,小数点后一位最大值,获得该最大值+1 ,得到既是新行的后缀,保证拆分是按照前后顺序递增的) 。
对 2.1 进行拆分得到的应该是 :2.1.4 首先要保证 每次拆分得到的下一行都是多一位小数点 。
对2.1 拆分 获取最大后缀 比较对象 时候 应该匹配前缀是2.1的 且只有两位小数点的 (排除前缀符合位数不符合的情况:2.1.1.1 ,2.1.1.2 ) 。
对3 进行拆分 没有历史记录是以 3开头的情况 这时候 就要重新 开始拆分:得到的应该是 3.1 。
这里的关键就是匹配历史记录进行比较,决定拆分后的最后一位的最大值 。
匹配的时候不能按照 数字的位数来判断,因为数字有可能是两位数,三位数,应该根据小数点来判断 。
匹配要使用到 正则表达式:
与PHP、Python一样Oracle 的正则表达式函数也是 主要由四个函数实现:相似匹配,定位查找,获取匹配子字符串,替换匹配结果(最重要) 。
(1)相似匹配: regexp_like() 。
regexp(source_str,pattern,match_parameter) 。
第一个参数:原字符串,第二个参数匹配模式,第三个参数匹配选项 。
第三个参数 匹配选项在这几个函数中都要相似作用(可选) 。
常用: i:大小写不敏感; c:大小写敏感; n:点号 . 不匹配换行符号; m:多行模式; x:扩展模式,忽略正则表达式中的空白字符.
匹配成功返回true 失败返回 false 。
我的使用:
IF REGEXP_LIKE(DEL_LINE_NUMBER, '^\d*\.\d*\.\d*$') THEN --匹配只有两个小数点的数字,字符串 。
模式中的符号说明:模式需要用一对双引号括起来 ^ 标明字符串的开头, $ 标明字符串的结尾 \d 匹配 一个0-9 的数字 * 号 匹配前面的字符0次或更多次 \. 匹配一个点号,因为点号有其他含义,所以用\作为转义 。
(2)定位查找字符位置:regexp_instr( ) 。
1
2
3
4
5
6
7
|
regexp_instr(source_string ,pattern,position,occurrence ,return_option ,match_parameter )
source_string:输入的字符串
pattern:正则表达式
position:标识从第几个字符开始正则表达式匹配。(默认为1)
occurrence:标识第几个匹配组。(默认为1)
return_option:0——返回第一个字符出现的位置。1:pattern下一个字符起始位置。
match_parameter:匹配模式
|
前面两个字段必输:
1
2
3
4
5
6
7
8
9
10
11
|
regexp_instr()
select
str,
regexp_instr(str,
'\.'
) ind , 默认从第一个字符开始查找,查找第一个.号,也可以匹配资格符合要求的字符串,写对匹配格式即可,不一定是单个字符
regexp_instr(str,
'\.'
,1,2) ind , 从第1个字符开始,查找第二个.号所在的位置
regexp_instr(str,
'\.'
,5,2) ind 从第五个字符开始,查找第二个.号的位置,注意最终查找到的字符和字符串的位置是相对于查找字符串的起始位置
fromtmp
where
id=
'instr'
;
STR IND IND IND
--------------- ----- ----- -----
192.168.0.1 4 8 10
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
select
regexp_instr(
'192.168.0.1'
,
'\.'
,1,
level
) ind ,
-- 点号. 所在的位置
regexp_instr(
'192.168.0.1'
,
'\d'
,1,
level
) ind
-- 每个数字的位置
fromdual
connectbylevel <= 9 连续匹配目标字符串出现的第一次出现的位置,第二次出现的位置,直到第九次出现的位置
IND IND
----- -----
4 1
8 2
10 3
0 5
0 6
0 7
0 9
0 11
-- 第八个数字所在位置为 11 这里不存在第九个数字,匹配不到,返回的地址为0
0 0
-- 没有匹配到时返回为0 ,对应第一位是从1开始,而不是0 开始
|
我的案例:
V_POSITION_BIT := REGEXP_INSTR(REC_DATA.DEL_LINE_NUMBER,'\.',1,2) -1; -- 第二个小数点的位数,减一 。
substr(DEL_LINE_NUMBER,1,V_POSITION_BIT) -- 获取字符串中第二个小数点之前的子串 。
(3) 获取匹配子字符串:regexp_substr() 。
regexp_substr(source_string ,pattern,position,occurrence ,match_parameter) 。
regexp_substr()在最初目的是根据字符串中某一个字符,分割字符串形成一个数组之类的 。
例如: 192.168.233.23 按点号"." 分组 最终结果有四个 :192 168 233 23 。
注意的是 pattern书写的格式不仅仅要用括号括起来,还要使用中括号括起来 。
我的案例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
REGEXP_SUBSTR(DEL_LINE_NUMBER,
'[^.]+'
,1,1)
-- 匹配前缀相同,第一个小数点前的字符
select
str,
regexp_substr(str,
'[^,]+'
) str,
regexp_substr(str,
'[^,]+'
,1,1) str, 从第一位开始匹配,获得用逗号分隔字符串之后,第一个‘分割后的子串
'
regexp_substr(str,'
[^,]+
',1,2) str, -- occurrence 第几个匹配组
regexp_substr(str,'
[^,]+
',2,1) str -- position 从第几个字符开始匹配
fromtmp
whereid='
substr';
STR STR STR STR STR
--------------- --------------- --------------- --------------- ---------------
123,234,345 123 123 234 23
12,34.56:78 12 12 34.56:78 2
123456789 123456789 123456789 逗号分割后不存在第二个 23456789(从第二位之后开始分割,没有就是取整体)
|
(4) 替换匹配结果:regexp_replace() 。
1
2
3
4
5
6
7
8
9
10
|
select
str,
regexp_replace(str,
'020'
,
'GZ'
) str,
regexp_replace(str,
'(\d{3})(\d{3})'
,
'<\2\1>'
) str
-- 将第1、第二捕获组交换位置,用尖括号标识出来
fromtmp
whereid=
'replace'
;
STR STR STR
--------------- --------------- ---------------
(020)12345678 (GZ)12345678 (020)<456123>78
001517729C28 001517729C28 <517001>729C28
|
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! 。
原文链接:http://blog.csdn.net/u013101979/article/details/62430645 。
最后此篇关于Oracle 正则表达式实例详解的文章就讲到这里了,如果你想了解更多关于Oracle 正则表达式实例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个加号/减号按钮,希望用户不能选择超过 20 个但不知道如何让它工作。我尝试使用 min="1"max="5 属性,但它们不起作用。这是我的代码和一个 fiddle 链接。https://jsf
我正在尝试复制顶部底部图,如示例 here但它没有正确渲染(紫色系列有 +ve 和 -ve 值,绿色为负值)留下杂乱的人工制品。我也在努力创建一个玩具示例来复制这个问题,所以我希望尽管我缺乏数据,但有
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 6 年前。 社区去年审查了是
这个问题在这里已经有了答案: Adding two positive integers gives negative answer.Why? (4 个答案) 关闭 5 年前。 我遇到了一个奇怪的问题
有谁知道如何将字符串值类型 -4,5 或 5,4 转换为 double -4.5 或 5.4? 最佳答案 只需使用 Double.parseDouble(Locale, String); 糟糕,我很困
我正在尝试根据 TextBlob 分类插入一个仅包含“正”或“负”字符串的新数据框列:对于我的 df 的第一行,结果是 ( pos , 0.75, 0.2499999999999997)我想要' 正
我对 VBA 非常陌生,无法理解如何在一个循环中完成 2 个任务。我非常感谢您的帮助。 我已经能够根据第 3 列中的数据更改第 2 列中的数值,但我不明白如何将负值的字体更改为红色。 表格的大小每月都
欢迎, 我正在使用 jquery 通过 POST 发送表单。 这就是我获得值(value)的方式。 var mytext = $("#textareaid").val(); var dataStrin
double d = 0; // random decimal value with it's integral part within the range of Int32 and always p
我有这个字符串: var a='abc123#xyz123'; 我想构建 2 个正则表达式替换函数: 1) 用 '*' 替换所有确实有 future '#'的字符(不包括'#') 所以结果应该是这样的
我正在使用 DialogFragment。当用户从 Gmail 平板电脑应用程序的屏幕与下面示例图片中的编辑文本进行交互时,我希望正面和负面按钮保持在键盘上方。 在我的尝试中不起作用,这是我的 Dia
从组装艺术一书中,我复制了这句话: In the two’s complement system, the H.O. bit of a number is a sign bit. If the H.O
是否有更好更优雅的方法来实现下面的简单代码(diffYear、A 和 B 是数字): diffYear = yearA - yearB; if (diffYear == 0) { A = B
我正在设计一种语言,并尝试确定 true 应该是 0x01 还是 0xFF。显然,所有非零值都将转换为 true,但我正在尝试确定确切的内部表示。 每种选择的优点和缺点是什么? 最佳答案 没关系,只要
在我的 dialogfragment 类的 OnCreateDialog 中,我正在这样做: AlertDialog.Builder builder = new AlertDialog.Builder
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda usin
我偶然发现了一个奇怪的 NSDecimalNumber 行为:对于某些值,调用 integerValue、longValue、longLongValue 等,返回意想不到的值(value)。示例: l
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda using
我有这个正则表达式来测试用户输入是否有效: value.length === 0 || value === '-' || (!isNaN(parseFloat(value)) && /^-?\d+\.
我想用高斯混合模型拟合数据集,数据集包含大约 120k 个样本,每个样本有大约 130 个维度。当我使用 matlab 执行此操作时,我运行脚本(簇号为 1000): gm = fitgmdist(d
我是一名优秀的程序员,十分优秀!