字典
最后更新于:2022-04-01 21:05:26
我们讲到的最后一种Vimscript类型将是字典。 Vimscript字典类似于Python中的dict,Ruby中的hash,和Javascript中的object。
字典用花括号创建。值是异质的,但_键会被强制转换成字符串_。就是这么简单,你没想到吧?
执行这个命令:
~~~
:echo {'a': 1, 100: 'foo'}
~~~
Vim显示`{'a':1,'100':'foo'}`,这说明Vimscript的确把键强制转换为字符串,同时保留值不变。
Vimscript避免了Javascript标准的蠢笨之处,允许你在字典的最后一个元素后留下一个逗号。 (译注:在Javascript的标准中,最后一个元素后面不能留下一个逗号。 但在Firefox里,留下那个逗号是允许的,不过这是Firefox的问题。) 执行下面的命令:
~~~
:echo {'a': 1, 100: 'foo',}
~~~
Vim再次显示`{'a':1,'100':'foo'}`(译注:结尾小逗号不见了)。你应该_总是_在字典里留下一个多余的逗号, _尤其_是当字典的定义跨越多行的时候,这样增加新项的时候将不容易犯错。
## 索引
查找字典中的一个值的语法跟大多数语言是一样的。执行这个命令:
~~~
:echo {'a': 1, 100: 'foo',}['a']
~~~
Vim显示`1`。试试使用不是字符串的索引:
~~~
:echo {'a': 1, 100: 'foo',}[100]
~~~
Vim会在查找之前把索引强制转换成字符串,因为键只能是字符串,这么做是合理的。
当键仅由字母,数字和/或下划线组成时,Vimscript也支持Javascript风格的"点"查找。 试试下面的命令:
~~~
:echo {'a': 1, 100: 'foo',}.a
:echo {'a': 1, 100: 'foo',}.100
~~~
两种情况下,Vim都显示了正确的元素。使用哪种索引字典的方式取决于你自己的偏好。
## 赋值和添加
像对待变量一样赋值给字典中的项,就可以在字典中轻松地添加新的项。
~~~
:let foo = {'a': 1}
:let foo.a = 100
:let foo.b = 200
:echo foo
~~~
Vim显示`{'a': 100, 'b': 200}`。赋值和添加一个新项的方式是一样的。
## 移除项
有两种方法可以移除字典中的项。执行下面的命令:
~~~
:let test = remove(foo, 'a')
:unlet foo.b
:echo foo
:echo test
~~~
Vim显示`{}`和`100`。`remove`函数将移除给定字典的给定键对应的项,并返回被移除的值。 `unlet`命令也能移除字典中的项,只是不返回值。
你不能移除字典中不存在的项。试试执行这个命令:
~~~
:unlet foo["asdf"]
~~~
Vim抛出一个错误。
选择`remove`还是`unlet`很大程度上取决于个人偏好。如果非要我说,我推荐使用`remove`, 因为它比`unlet`更灵活。`remove`可以做任何`unlet`能做的事,反过来不成立。 所以选择`remove`可以一招鲜,吃遍天。
## 字典函数
就像列表,Vim有许许多多内置的字典函数。执行下面的命令:
~~~
:echom get({'a': 100}, 'a', 'default')
:echom get({'a': 100}, 'b', 'default')
~~~
Vim显示`100`和`default`,如同列表版本的`get`函数.
你也可以检查给定字典里是否有给定的键。执行这个命令:
~~~
:echom has_key({'a': 100}, 'a')
:echom has_key({'a': 100}, 'b')
~~~
Vim显示`1`和`0`。不要忘了,Vimscript把`0`当作假而其他数字则是真。
你可以用`items`从一个字典中获取对应的键值对,执行这个命令:
~~~
:echo items({'a': 100, 'b': 200})
~~~
Vim将显示`[['a',100],['b',200]]`这样的嵌套列表。到目前为止,Vimscript字典_不一定_是有序的, 所以不要指望`items`的返回结果是有序的!
你可以用`keys`返回字典的所有的键和`values`返回所有的值。它们的作用一如其名——你可以查一下。
## 练习
阅读`:help Dictionary`。看完它。注意大写`D`。
阅读`:help get()`.
阅读`:help has_key()`.
阅读`:help items()`.
阅读`:help keys()`.
阅读`:help values()`.
';