- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近一直在玩 vim 宏(目前在 MacVim 中),有时我喜欢使用例如显式地将宏分配到寄存器中:let @a='(macro keystrokes)'
.这通常工作正常,但我发现一个奇怪的行为,每当我分配一个以回车符/^M 结尾的字符串值时,vim 会在将它放入寄存器之前自动在末尾添加一个换行符/^J,这会影响执行宏!
示例:假设我录制了一个简单的宏,它进入插入模式,键入“嘿”,退出插入模式,然后按两次 Enter 进入 2 行。我通过输入 qaihey<Escape><Enter><Enter>q
将其记录到寄存器 @a 中,它将以下内容存储在@a中:
ihey^[^M^M
到目前为止一切顺利,通过键入 @a
执行宏做它应该做的。另一种非常好的方法可以让这个相同的宏进入寄存器@a 是通过将整个东西( ihey<Ctrl-V><Escape><Ctrl-V><Enter><Ctrl-V><Enter>
)键入缓冲区然后用 "ay
猛拉它——最终结果是一样的。但奇怪的是——假设我只是想使用 let
将该字符串直接分配给@a。声明:
:let @a='ihey^[^M^M'
现在如果我输入 :reg
看看它说的值(value)有一个额外的^J
最后出于某种原因:
"8 ...
"9 ...
"a ihey^[^M^M^J
"b ...
有额外的^J
导致它在我执行宏时多走一行,所以它实际上改变了行为。
有人知道为什么要添加这个额外的字符吗?任何人都知道我如何获得以 ^M
结尾的字符串值进入寄存器(或任何变量),而无需额外的 ^J
被添加?
最佳答案
一些快速检查 vim 帮助文件说:
:let @{reg-name} = {expr1} *:let-register* *:let-@*
...
If the result of {expr1} ends in a <CR> or <NL>, the
register will be linewise, otherwise it will be set to
characterwise.
换句话说,以回车符结尾的字符串将使 Vim 将其解释为行结尾
快速谷歌搜索 this来自 VimTips wiki:
Note however, that the above method using :let will not work as expected for any macros which you make ending in a < CR > or < NL > character (carriage return or newline). This is because, as documented in :help :let-@, Vim will treat the register as "linewise" under these conditions. The reason for this is to make registers set with :let act "the right way" when dealing with yanked/deleted text, but it can cause headaches when dealing with recorded macros. Possible workarounds include using the setreg() function or adding "no-op" commands to the end of the macro, such as a < ESC >. See the discussion on vim_dev about unexpected behavior of the :let command for details.
因此您有几个选择:使用 setreg()
或在使用 let
时向字符串添加某种无操作序列 (< ESC >)。
关于macros - 如何在不添加 <LF> 的情况下将以 <CR> 结尾的字符串分配给 vimscript 变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20171382/
我正在编写在 Windows 中运行并输出文本文件的代码,该文本文件后来成为 Linux 程序的输入。当给定的文件具有 CR+LF 而不仅仅是 LF 的换行符时,此程序的行为不正确。 我知道我可以使用
我想知道之间的区别(如果可能的话提供示例)CR LF (Windows)、LF (Unix) 和 CR (Macintosh) 换行符类型。 最佳答案 CR和LF是控制字符,分别编码为0x0D(十进制
我们有一个名为 LineFeed.sh 的 shell 脚本文件它执行将换行符( LF )转换为回车+换行符的功能。我们希望通过 windows 中的批处理文件完成相同的操作。是否可以? Linux
我想查询我的表中有多少行包含一个或多个 实例。我想不出正确的语法。我会尝试 LIKE '%%',但我不知道如何指定这些特殊字符。我试过 where mydata REGEXP '%[.CR.][.LF
我必须编写一个功能类似于 dos2unix 的 C 程序。它将所有 CR LF 替换为仅 LF(DOS 格式到 Unix 格式)。所以这是我的方法。每次我读一行时,我通过查找 \0 来搜索数据的结尾,
我有一个 UTF-16 编码的文件,我想用 Windows 行结尾替换 UNIX 行结尾。我不想碰其他任何东西。 有没有linux命令行工具可以搜索两个字节“0A 00”并用四个字节“0D 00 0A
在 Windows 上 #include int main() { putc('A',stdout); putc('\r',stdout); putc('\n',stdout
在 Windows 中,当您以文本模式从文件(或标准输入)读取字符 \r\n 时,\r 被删除,您只能读取 \n. 是否有一个标准应该如此? 我能确定这对 Windows 上的任何编译器都是正确的吗?
我被聘为顾问,与糟糕的内部人员一起工作 DSL被一家大公司使用。 我说糟糕是因为代码行不是用回车符或换行符来结束每行代码,而是用五个字符的 ASCII 字符串 分隔的。 .这些文件有数千“行”长。任
我正在 Windows 10 上开发一个 Unity 3D C# 项目,并开始一个新的存储库,我将其添加到我的 .gitattributes 中。文件: # These files are text
我正在 Linux 平台上编写一个程序,该程序生成的文本文件将不可避免地在 Windows 平台上查看。 现在,将 std::endl 传递到 ostream 中仅为换行符生成 CR 字符。当然,这些
交换换行符(例如通过某些文本编辑器)是否会破坏 javascript 代码? 最佳答案 两个控制字符都是valid line breaks .事实上你甚至不需要换行符。这只是为了更好的可读性。除了在字
在 MS Windows 上,使用 Python 3 的 pyodbc 模块,我正在使用 PostgreSQL。当我使用 PostgreSQL 的 TEXT 数据类型并尝试存储类 UNIX 的 EOL
我正在学习 C,我有以下代码: #include #include #include int main(int argc, char *argv[]) { double x; print
我想强制 Git 在 Windows 下使用 LF 而不是 CR+LF check out 文件。 我检查了两个配置选项,但无法找到正确的设置组合。 我想将所有文件转换为具有 LF 换行符并在文件中保
我是一名 Java 开发人员,我正在使用 Ubuntu 进行开发。该项目是在 Windows 中使用 Eclipse 创建的,它使用 Windows-1252编码。 为了转换为 UTF-8,我使用了
我有一个字符串,我想控制它的字符串内容 是否包含 (CR、LF 或 CRLF)? if (no CR, LF or CF or LF) in string: echo 'no sepator
我有一个包含“unix 风格”行尾的文本文件:每行末尾有一个 0x0A。 我正在编写一个脚本来修改该文件,以向其中添加新内容。这是在 Windows 上运行的 JScript。代码如下所示:
为什么 Firefox 和 Chrome 在 POST 时将 LF 字符替换为 CR+LF? 我写了以下内容作为测试: function lftest() { var linefeed
这与这个问题非常相似: What is the differrence between `* text=auto` and `* text eol=lf` in .gitattributes? 但我特
我是一名优秀的程序员,十分优秀!