我想用来tr
做一些 rot13 转换。我可以很好地理解这个命令:
tr A-Za-z N-ZA-Mn-za-m <<< "URYC ZR CYRNFR"
哪个输出是HELP ME PLEASE
,但我不知道这个其他命令如何产生相同的 rot13 转换:
tr .............A-Z A-ZA-Z <<< "URYC ZR CYRNFR"
所以我有两个问题:
tr
第二个命令背后的魔力是什么?- 如何使第二个命令对小写和大写都有效,就像第一个命令一样?
我想用来tr
做一些 rot13 转换。我可以很好地理解这个命令:
tr A-Za-z N-ZA-Mn-za-m <<< "URYC ZR CYRNFR"
哪个输出是HELP ME PLEASE
,但我不知道这个其他命令如何产生相同的 rot13 转换:
tr .............A-Z A-ZA-Z <<< "URYC ZR CYRNFR"
所以我有两个问题:
tr
第二个命令背后的魔力是什么?
它的工作原理如下:
所以
tr
会翻译SET1
成SET2
.这相当于第一个,因为它也按
13
单位移动,因为有 13 个点。要包含小写字母,您必须以
SET1
类似的偏移量排列它们,即:Z
那是和之间的 26 个点a
,跨越一半的大写字母和一半的小写字母。所以tr
命令本身将是:正如@Prvt_Yadv 在他们的回答中所说,它之所以有效,是因为有 13 个点。
套装是
The dot isn't a special character, so if you have a dot in your input, it will be translated too. In the version of
tr
that I have, it is the last corresponding character in the second set, in this case anM
:(I could imagine that a different version of
tr
might use the first matching character in set 2, which would give anA
.)To answer your second question, you need another 13 dots in the first set to "use up" the remaining uppercase letters in set 2:
then you can repeat the pattern:
which gives us:
And so:
Personally, I think the first way of doing it in your question is simpler!
The first way also doesn't transform any other characters in the input. For example, compare:
with
好的,感谢@Prvt_Yadv,我能够理解这些点。这是第一个问题的答案:
13 个点只是被映射到第二组的前 13 个字母。所以
tr .............A-Z A-ZA-Z
将产生以下集合:如果您的输入不包含点,则可以丢弃初始序列,因为您不会使用这些替换。然后集合将变为:
但是由于第一个集合已经包含了所有 26 个字母并且 set2 有重复的尾随字母,所以这些也被丢弃了,最后变成了
这是 rot13 替换,与第一个命令相同(除了这里不处理小写)。相同的逻辑可以应用于问题的标题:
tr ...A-Z A-ZA-Z <<< “JVPQBOV”
将产生集合:丢弃初始序列和它们变成的尾随重复字母:
这是 rot3 替换。
现在来说第二个问题:
为了使它起作用,您将所需数量的点放在开头,将您的 rot 和 26 个点匹配到上序列和下序列之间,就像这样:
这将成功创建一个不敏感的 rot8。为了形象化为什么这有效,让我们看看这些集合:
不包括点映射和尾随字母:
现在它适用于大写和小写:)
使其工作的另一种方法是使用
tr
以下两个命令:@iruvar 给出了使用点替换的警告:当输入字符串包含点时,此命令将无法按预期工作。这是因为点被映射到其他字母,并且在进行替换时,
tr
会将输入点更改为最后一个映射的字母。但您实际上可以使用点以外的任何其他字符。因此,如果在您的tr
命令中使用点是一个问题,您可以使用@
,例如。这同样适用: