- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
请注意,我想在字符串中查找我指定以外的特殊字符。
DECLARE @Temp1 NVARCHAR(100)
SET @Temp1 ='Rajesh[sdf]'
SELECT PATINDEX('%[^0-9A-Za-z .&()[[,''-]%',@Temp1)
经过长时间的发现,我得到了允许左方括号我们必须放两次 [ 即 [[但这不是右括号的情况表达式 PATINDEX('%[^0-9A-Za-z .&()[[],''-]%',@Temp1) 没有给出预期的正确结果。 p>
DECLARE @Temp1 NVARCHAR(100)
SET @Temp1 ='Rajesh[sdf]'
SELECT PATINDEX('%[^0-9a-z .&()[[],''-]%',@Temp1)
上面的代码返回 patindex 0 因为我已经删除了大写字母。对于“R”的匹配,它应该返回 1。那么什么是右括号的正确匹配。
最佳答案
根据 this link ,看起来 [[
不是 [
的转义,而是 [[]
的转义。换句话说,左方括号在左右方括号对中。
既然如此,你的PATINDEX
应该如下所示。
PATINDEX('%[^0-9A-Za-z .&()[[]],''-]%',@Temp1)
注意附加的 ]
,因为第一个 ]
关闭了 []
对以匹配 [
。
编辑#1:
如果你要尝试这样的事情会怎样?我们正在做的是首先用 ()
替换烦人的 []
字符,然后搜索不在列表中的特殊字符。
DECLARE @Temp1 NVARCHAR(100)
SET @Temp1 ='Rajesh[sdf]'
SET @Temp1 = REPLACE(@Temp1,'[','(')
SET @Temp1 = REPLACE(@Temp1,']',')')
SELECT PATINDEX('%[^0-9A-Za-z .&(),''-]%',@Temp1)
不幸的是,我现在无法对此进行测试,因为此时我没有 SQL Server 的工作副本。一旦我安装了一个,我会尝试测试一下。
编辑#2:
现在我已经能够测试了,我已经确认这是一个可能的解决方案。
DECLARE @Temp1 NVARCHAR(100)
SET @Temp1 ='Rajesh[sdf]+'
SET @Temp1 = REPLACE(@Temp1,'[','.')
SET @Temp1 = REPLACE(@Temp1,']','.')
SET @Temp1 = REPLACE(@Temp1,'-','.')
SELECT PATINDEX('%[^0-9a-z .&(),'']%',@Temp1 COLLATE Latin1_General_BIN)
有几个挑战需要克服。
COLLATE
来解决这个问题。请注意,我使用了 BIN
归类,因为即使是 CS
归类也没有按预期运行。这解决了删除 A-Z
仍然不匹配 R
的问题。PATINDEX
表达式中的 -
字符无法正常工作。这可能是因为它是表达式中的特殊字符(即 a-z
中的“through”)。我尝试像 --
一样转义它,虽然这有效,但我的附加测试用例 +
被破坏了。我发现这真的很奇怪,但最终决定将 -
替换为另一个我知道我会拒绝的字符 (.
) 可能更容易。REPLACE
函数通过从表达式中完全删除有问题的特殊字符来降低 PATINDEX
的复杂性(并使其真正起作用)。假设您在 PATINDEX
中始终至少有一个要拒绝的字符,那么使用这些 REPLACE
表达式应该是一种可行的解决方案。从理论上讲,它会稍微减慢速度,但这只是必须在现实生活中进行测试才能确定它是否重要。我知道这个解决方案有效,因为我已经能够对其进行测试。只需要一点时间来启动和运行 SQL Server Express Edition!
关于regex - TSQL 也允许匹配来自字符串的右方括号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13916350/
我一直想知道两者之间有什么区别 mov esi,eax 和 mov [esi],eax 曾经是。 感谢任何帮助。 最佳答案 mov esi,eax 将寄存器eax的内容写入寄存器esi。 mov [e
如果有人能帮助我满足 JAVA 正则表达式要求,我将不胜感激我有一个像 "/ABC/KLM[XYZ/ABC/KLM]/ABC"这样的字符串 我想替换所有不用方括号括起来的ABC。在这种情况下,只应找到
我需要替换 key:value 对周围的方括号,类似于以下内容。任何帮助深表感谢! “属性”中的数据如下所示: name: property1 value: [12345667:97764458] *
我正在尝试使用某种 grok 模式来使用以下日志记录格式: *Sun 07:05:18.372 INFO [main] [userID] perf - 0ms - select x from y 我
我在 R 中有一个函数,看起来有点像这样: setMethod('[', signature(x="stack"),definition=function(x,i,j,drop){ new('cl
我将这些定义放在一个文件中: x = 'a' : 'b' : 'c' : [] y = ['a', 'b', 'c'] (重要的是在文件中定义它们,而不是在 GHCi 中,因为在后一种情况下,事情变得
我喜欢将DocBlockr插件用于精美文字,但我希望自己的评论有所不同。 正常出现: 以及我希望它们出现的方式: 因此,是否有这样做的type,description和[]方括号呢?我已经搜寻了一下,
让我们考虑以下是我的对象: var n = {"aa":"x","dd":'d'}; 我在 Object.assign 中使用方括号.它给出了以下结果。 [aa: "x", dd: "d"] .最终代
我正在尝试使用正则表达式从 KEY PAIR VALUE 中找出 VALUE。 VALUE 可以有 [ ](方括号)。如果 VALUE 中存在 [ ](方括号),那么我只想提取 [ ] 之外的字符。
这个问题在这里已经有了答案: What is array literal notation in javascript and when should you use it? (4 个答案) 关闭
这个问题在这里已经有了答案: What do square brackets around a property name in an object literal mean? (2 个答案) 关闭
我有一个语法标记指定为: list_value = Suppress(oneOf("[ (")) + Group( delimitedList(string_value | int_value
如何替换这种格式的标记: [a href="/my_page" style="font-size: 13px"]click me[/a] 到 click me 使用 preg_replace()? 我
使用下面的代码,我可以将 Number123(45) 转换为 Number。 $string = 'Number123(45)'; $string2 = preg_replace('/[0-9]+
我知道硬括号('[' 和 ']')用于标识数组,但是在搜索如何使用事件时,我偶然发现了它们的另一种用法,并且想知道它到底意味着什么...... 我看到的代码 ( link ) 如下所示: // evh
This question already has an answer here: gRPC/Protobuf 3 syntax: what is the difference between rpc
在vim中,您可以通过vi“,vi [,vi(... 例如,如果您有这样的一行: x = "difference between vim and emacs" 并且光标位于这些引号之间的任意位置,然后
AngularJS将方括号用作其指令的参数 (input[number]) 但是Jade also uses square brackets for class attributes。 所以这行不通
正则表达式中的点. 匹配任何单个字符。为了使正则表达式匹配点,必须对点进行转义:\. It has been pointed out to me方括号 [] 内的点不必转义。例如,表达式:[.]{3}
这个问题已经有答案了: What is the difference between square brackets and parentheses in a regex? (3 个回答) 已关闭 8
我是一名优秀的程序员,十分优秀!