vim command

命令历史

以:和/开头的命令都有历史纪录,可以首先键入:或/然后按上下箭头来选择某个历史命令。

启动vim

在命令行窗口中输入以下命令即可

vim 直接启动vim

vim filename 打开vim并创建名为filename的文件

文件命令

打开单个文件

vim file

同时打开多个文件

vim file1 file2 file3 …

在vim窗口中打开一个新文件

:open file

在新窗口中打开文件

:split file

切换到下一个文件

:bn

切换到上一个文件

:bp

查看当前打开的文件列表,当前正在编辑的文件会用[]括起来。

:args

打开远程文件,比如ftp或者share folder

:e ftp://192.168.10.76/abc.txt

:e \\qadrive\test\1.txt

vim的模式

正常模式(按Esc或Ctrl+[进入) 左下角显示文件名或为空
插入模式(按i键进入) 左下角显示–INSERT–
可视模式(不知道如何进入) 左下角显示–VISUAL–

导航命令

% 括号匹配

插入命令

i 在当前位置前插入

I 在当前行首插入

a 在当前位置后插入

A 在当前行尾插入

o 在当前行之后插入一行

O 在当前行之前插入一行

查找命令

/text  查找text,按n健查找下一个,按N健查找前一个。

?text  查找text,反向查找,按n健查找下一个,按N健查找前一个。

vim中有一些特殊字符在查找时需要转义  .*[]^%/?~$

:set ignorecase  忽略大小写的查找

:set noignorecase  不忽略大小写的查找

查找很长的词,如果一个词很长,键入麻烦,可以将光标移动到该词上,按*或#键即可以该单词进行搜索,相当于/搜索。而#命令相当于?搜索。

:set hlsearch  高亮搜索结果,所有结果都高亮显示,而不是只显示一个匹配。

:set nohlsearch  关闭高亮搜索显示

:nohlsearch  关闭当前的高亮显示,如果再次搜索或者按下n或N键,则会再次高亮。

:set incsearch  逐步搜索模式,对当前键入的字符进行搜索而不必等待键入完成。

:set wrapscan  重新搜索,在搜索到文件头或尾时,返回继续搜索,默认开启。

替换命令

ra 将当前字符替换为a,当期字符即光标所在字符。

s/old/new/ 用new替换old,替换当前行的第一个匹配

s/old/new/g 用new替换old,替换当前行的所有匹配

%s/old/new/ 用new替换old,替换所有行的第一个匹配

%s/old/new/g 用new替换old,替换整个文件的所有匹配

:10,20 s/^/    /g 在第10行至第20行每行前面加四个空格,用于缩进。

ddp 交换光标所在行和其下紧邻的一行。

移动命令

h 左移一个字符
l 右移一个字符,这个命令很少用,一般用w代替。
k 上移一个字符
j 下移一个字符
以上四个命令可以配合数字使用,比如20j就是向下移动20行,5h就是向左移动5个字符,在Vim中,很多命令都可以配合数字使用,比如删除10个字符10x,在当前位置后插入3个!,3a!<Esc>,这里的Esc是必须的,否则命令不生效。

w 向前移动一个单词(光标停在单词首部),如果已到行尾,则转至下一行行首。此命令快,可以代替l命令。

b 向后移动一个单词 2b 向后移动2个单词

e,同w,只不过是光标停在单词尾部

ge,同b,光标停在单词尾部。

^ 移动到本行第一个非空白字符上。

0(数字0)移动到本行第一个字符上,

<HOME> 移动到本行第一个字符。同0健。

$ 移动到行尾 3$ 移动到下面3行的行尾

gg 移动到文件头。 = [[

G(shift + g) 移动到文件尾。 = ]]

f(find)命令也可以用于移动,fx将找到光标后第一个为x的字符,3fd将找到第三个为d的字符。

F 同f,反向查找。

跳到指定行,冒号+行号,回车,比如跳到240行就是 :240回车。另一个方法是行号+G,比如230G跳到230行。

Ctrl + e 向下滚动一行

Ctrl + y 向上滚动一行

Ctrl + d 向下滚动半屏

Ctrl + u 向上滚动半屏

Ctrl + f 向下滚动一屏

Ctrl + b 向上滚动一屏

撤销和重做

u 撤销(Undo)
U 撤销对整行的操作
Ctrl + r 重做(Redo),即撤销的撤销。

删除命令

x 删除当前字符

3x 删除当前光标开始向后三个字符

X 删除当前字符的前一个字符。X=dh

dl 删除当前字符, dl=x

dh 删除前一个字符

dd 删除当前行

dj 删除上一行

dk 删除下一行

10d 删除当前行开始的10行。

D 删除当前字符至行尾。D=d$

d$ 删除当前字符之后的所有字符(本行)

kdgg 删除当前行之前所有行(不包括当前行)

jdG(jd shift + g)   删除当前行之后所有行(不包括当前行)

:1,10d 删除1-10行

:11,$d 删除11行及以后所有的行

:1,$d 删除所有行

J(shift + j)  删除两行之间的空行,实际上是合并两行。

拷贝和粘贴

yy 拷贝当前行

nyy 拷贝当前后开始的n行,比如2yy拷贝当前行及其下一行。

p  在当前光标后粘贴,如果之前使用了yy命令来复制一行,那么就在当前行的下一行粘贴。

shift+p 在当前行前粘贴

:1,10 co 20 将1-10行插入到第20行之后。

:1,$ co $ 将整个文件复制一份并添加到文件尾部。

正常模式下按v(逐字)或V(逐行)进入可视模式,然后用jklh命令移动即可选择某些行或字符,再按y即可复制

ddp交换当前行和其下一行

xp交换当前字符和其后一个字符

剪切命令

正常模式下按v(逐字)或V(逐行)进入可视模式,然后用jklh命令移动即可选择某些行或字符,再按d即可剪切

ndd 剪切当前行之后的n行。利用p命令可以对剪切的内容进行粘贴

:1,10d 将1-10行剪切。利用p命令可将剪切后的内容进行粘贴。

:1, 10 m 20 将第1-10行移动到第20行之后。

退出命令

:wq 保存并退出

ZZ 保存并退出

:q! 强制退出并忽略所有更改

:e! 放弃所有修改,并打开原来文件。

窗口命令

:split或new 打开一个新窗口,光标停在顶层的窗口上

:split file或:new file 用新窗口打开文件

split打开的窗口都是横向的,使用vsplit可以纵向打开窗口。

Ctrl+ww 移动到下一个窗口

Ctrl+wj 移动到下方的窗口

Ctrl+wk 移动到上方的窗口

关闭窗口

:close 最后一个窗口不能使用此命令,可以防止意外退出vim。

:q 如果是最后一个被关闭的窗口,那么将退出vim。

ZZ 保存并退出。

关闭所有窗口,只保留当前窗口

:only

录制宏

按q键加任意字母开始录制,再按q键结束录制(这意味着vim中的宏不可嵌套),使用的时候@加宏名,比如qa。。。q录制名为a的宏,@a使用这个宏。

执行shell命令

:!command

:!ls 列出当前目录下文件

:!perl -c script.pl 检查perl脚本语法,可以不用退出vim,非常方便。

:!perl script.pl 执行perl脚本,可以不用退出vim,非常方便。

:suspend或Ctrl – Z 挂起vim,回到shell,按fg可以返回vim。

注释命令

perl程序中#开始的行为注释,所以要注释某些行,只需在行首加入#

3,5 s/^/#/g 注释第3-5行

3,5 s/^#//g 解除3-5行的注释

1,$ s/^/#/g 注释整个文档。

:%s/^/#/g 注释整个文档,此法更快。

帮助命令

:help or F1 显示整个帮助
:help xxx 显示xxx的帮助,比如 :help i, :help CTRL-[(即Ctrl+[的帮助)。
:help ‘number’ Vim选项的帮助用单引号括起
:help <Esc> 特殊键的帮助用<>扩起
:help -t Vim启动参数的帮助用-
:help i_<Esc> 插入模式下Esc的帮助,某个模式下的帮助用模式_主题的模式
帮助文件中位于||之间的内容是超链接,可以用Ctrl+]进入链接,Ctrl+o(Ctrl + t)返回

其他非编辑命令

. 重复前一次命令

:set ruler?  查看是否设置了ruler,在.vimrc中,使用set命令设制的选项都可以通过这个命令查看

:scriptnames  查看vim脚本文件的位置,比如.vimrc文件,语法文件及plugin等。

:set list 显示非打印字符,如tab,空格,行尾等。如果tab无法显示,请确定用set lcs=tab:>-命令设置了.vimrc文件,并确保你的文件中的确有tab,如果开启了expendtab,那么tab将被扩展为空格。

Vim教程
在Unix系统上
$ vimtutor
在Windows系统上
:help tutor

:syntax 列出已经定义的语法项
:syntax clear 清除已定义的语法规则
:syntax case match 大小写敏感,int和Int将视为不同的语法元素
:syntax case ignore 大小写无关,int和Int将视为相同的语法元素,并使用同样的配色方案

Dora Zhang

张迪,女,23,北京科技大学,计算机科学与技术研究生,一年级在读

e-mail: dora_zhangdi@163.com

自我认定:是一个精力充沛,正能量的程序媛。认真,团队意识强。

喜欢逻辑思考。热爱编程,享受调试。立志在程序的道路上越走越远,越宽越好。

项目经历

2014.10 – 2015.02                南宁市城市交通评价与预测系统                          开发

开发环境:Linux,python

数据存储:基于时间的文件索引

工具:python, js,html

实现了道路交通拥堵预测功能,依据实时数据和历史道路拥堵数据提取交通数据特征,使用线性回归方法lasso训练交通拥堵模型,搭建预测模型,以5 min为间隔预测交通拥堵值

前端:使用leaflet.js实现了前端地图显示,添加标记,绘制拥堵状态

2013.11 – 2014.07                远达国际信息管理系统                                                       开发

开发环境:eclipse,tomcat

数据库:oracle

工具:java,js,jsp

实现了工程管理模块页面及后台功能,建立工程管理表单:工程暂停令,工作联系单,监理通知,监理日志,会议纪要,工程信息

实现了表单数据的PDF导出,使用free-marker生成各表单的PDF

2013.06 – 2013.10     校园二手交易平台的实现及推广(国家级大学生创业项目)     开发

开发环境:BAE

工具:php,mysql,

负责项目数据库设计,个人信息界面设计,实现了后台的商品数据查询接口

2013.10  PickMe 可觅闲置商品交易平台上线   http://pickme.cn

2012.06 – 2013.03   智能题库管理系统的研究与实现(北京市级大学生创新项目)   领队

开发环境:window,.net framework

工具: .net,sql server

在项目中负责项目的立项申请和结题验收,整体把握开发进度。

负责系统界面和数据库的设计及实现,实现了知识点识别功能,对于试题提取出关键词,使用文本聚类方法识别出试题的相应知识点

项目结题优秀,著有软件著作权一项

成果获得第四届“蓝桥杯”全国软件大赛软件团队赛选拔赛一等奖

实习经历

2013.06 – 2013.10                            大麦网•技术中心                                           .NET开发

点映项目: 以众筹的方式发布演唱会项目,在规定时间内满足资金需求则项目启动。

点映项目主要包含三个模块,项目发布模块,终极页模块、声援模块。其中项目发布模块作为后台管理模块,是在线声援的基础;声援模块完成用户从开始声援到完成交易的整个过程。

前台页面包括项目终极页、确认订单页、支付中心页、支付成功页、订单管理页、订单详情页。后台管理包括新建项目和订单管理。

在项目中担任技术经理,执行了基于MVC开发框架的系统模块设计和数据库设计,使用MS project根据每一个开发人员的估计进度进行任务分配,使用Redmine进行任务指派和管理以及测试任务的分配管理。开发任务中负责了公共基类和终极页的实现。

比赛经历

2013.11                                      百度云编程马拉松(2 days)                                 三等奖

实时公交预测,解决每日坐公交用户的需求——不知道要等的那趟公交车到底还有多久才到。

用户需要面对的是多辆不同线路公交车的选择,帮助快速选择该坐哪一趟车,找出公交出行的最优解。通过众包的方式及与公交系统的对接来实现对公交车进程的实时查询、有效判断选择的路线。

工具:html5,百度地图API

服务器:node.js

体验:在最短的时间内尽量做到了能做的事情。

2013.07                                     百度黑客马拉松创客比赛                  闲置物品交易平台

2013.06        “蓝桥杯”全国软件大赛软件团队赛选拔赛                                      一等奖

2013.05       “蓝桥杯”全国软件专业人才设计与创业大赛C/C++程序设计本科A组  优秀奖

在校概况

2014.09 – 今            研究生(校外保送)       北京科技大学                   计算机科学与技术

人工鱼与智能生命实验室

2010.09 – 2014.06      本科                                北京林业大学                          数字媒体艺术

信息学院学生事务中心 副主席

学习成绩优秀,综合排名保持专业前3%

获得新生特等奖学金(专业仅1人)、优秀学生一等奖学金2次(专业前3%)

校级三好学生2次

优秀学生干部1次

以第二作者发表(导师第一作者)论文Programs Similarity Measure Based on Tree Structure and Eigenvector,EI检索

技能/爱好

语言能力

英语 CET-6         口语良好

日语(N2没过) 基础读写

爱好:瑜伽、游泳、徒步;动漫

python log 3 done

判断一个数字处于某个值域,可以 1<x<10,也可以 x in range(1,10),其中range(1,10)是10>x>=1,包含1不包含10。

range(0,10)可以直接赋值给一个list。

序数,ordinal number

基数,cardinal number

 

If 语句的规则:

1. 每一个“if语句”必须包含一个else。

2. 如果这个“else”永远都不应该被执行到,因为它本身没有任何意义,那你必须在else语句后面使用一个dead/die函数,让它打印出错误信息并且死给你看,可以找出很多错误。

3. “if语句”的嵌套不要超过2层,最好尽量保持只有1层。如果在if里面又有了一个if,那你就需要把第二个if移到另一个函数里去。

4. 将“if语句”当做段落来对待,其中的每一个if,elif,else组合的最前面和最后面留一个空行加以区分。

5. 布尔条件测试应该很简单,如果很复杂的话,需要将它们的运算事先放到一个变量里,并且为变量取一个好理解的名字。

遵循上面的规则,会写出比大部分程序员都易读更好的代码。但在日常编程中不要成为这些规则的奴隶。觉得很蠢就不要用。

 

循环的规则:

1. 只有在循环永不停止时使用“while循环”,可能永远用不到。这条只在python中成立。

2. 其他类型的循环都使用“for循环”,尤其是在循环的对象数量固定或有限的情况下。

规则是可以打破的!

TIPS:

每个程序员在开始一个新的大项目时,都会被非理性的恐惧影响到。为了避免这种恐惧,他们会拖延时间,到最后一事无成。避免这种情况的最好的方法是把自己要做的事情列出来,一次完成一样。

 

join方法 是连接string中的元素

str.join = join(…)

    S.join(iterable) -> string

    Return a string which is the concatenation of the strings in the

    iterable.  The separator between elements is S.

eg:

>>> s=”abcd”

>>> “,”.join(s)

‘a,b,c,d’

>>> “,”.join([‘a’,’b’,’c’])

‘a,b,c’

>>> “,”.join((‘a’, ‘b’, ‘c’))

‘a,b,c’

>>> “,”.join({‘a’:1, ‘b’:2, ‘c’:3})

‘a,c,b’

join的四个参数有str,list,tuple,dict

Python主要有三种数据类型:字典、列表、元组。
分别由花括号,中括号,小括号表示。
字典:dic={'a':1,'b':3}
列表:list=[1,2,3,4]
元组:tup=(1,2,3,4)

dir(something)

给dir()提供一个模块名字,返回在那个模块中定义的名字的列表。对于一个模块,包括在模块中定义的函数,类和变量。

当没有为其提供参数时, 它返回当前模块中定义的名字的列表。

>>> dir(list)

[‘__add__’, ‘__class__’, ‘__contains__’, ‘__delattr__’, ‘__delitem__’, ‘__delslice__’, ‘__doc__’, ‘__eq__’, ‘__format__’, ‘__ge__’, ‘__getattribute__’, ‘__getitem__’, ‘__getslice__’, ‘__gt__’, ‘__hash__’, ‘__iadd__’, ‘__imul__’, ‘__init__’, ‘__iter__’, ‘__le__’, ‘__len__’, ‘__lt__’, ‘__mul__’, ‘__ne__’, ‘__new__’, ‘__reduce__’, ‘__reduce_ex__’, ‘__repr__’, ‘__reversed__’, ‘__rmul__’, ‘__setattr__’, ‘__setitem__’, ‘__setslice__’, ‘__sizeof__’, ‘__str__’, ‘__subclasshook__’, ‘append’, ‘count’, ‘extend’, ‘index’, ‘insert’, ‘pop’, ‘remove’, ‘reverse’, ‘sort’]

class Song(object):

#object是类实例化时传进来的对象

#在__init__函数中,参数即是类实例化时的参数对象

        def __init__(self, lyrics):

                self.lyrics = lyrics

#在函数中 调用self,self即可看作一个数据对象,在下面的函数中调用了self的lyrics数据。

        def sing_me_a_song(self):

                for line in self.lyrics:

                        print line

#在实例化happy_birthday这个对象时,参数作为Song这个类的参数传了进去。

happy_birthday = Song([“Happy birthday to you”,

                        “I don’t want to get sued”,

                        “So I’ll stop right here”])

 

 

python log 2 done

“%r\n%r\n%r\n” % (line1, line2, line3)是一个string格式,格式化的字符串,可以作为一个参数传入函数。比如,

line1 = raw_input(“line 1: “)

line2 = raw_input(“line 2: “)

line3 = raw_input(“line 3: “)

print “Now I’m going to write these to the file.”

target.write(“%r\n%r\n%r\n” % (line1, line2, line3))

cat  连接 concatenate

open(file).read() 无需再执行close () ,因为read()一旦运行,文件就会被读到结尾并被close掉。

*args  是一个list,参数解包 unpack

f = open(file), 然后执行f.seek(0) 文件读写头回到文件的开始

在read()之后调用readline()要先调用seek(0)回到文件的开始,不然此时read()之后的读取位置是在文件末尾,再调用readline()读取不到内容。

print的句尾加一个逗号, print不会把\n打出来换行

import modules时不需要加.py后缀

帮助文档是定义函数时放在””” “””之间的 是documentation comments,文档注解

在自己写的模块中 help(test25),出现下面的解释,COOL.

Help on module test25:

NAME

    test25 – #coding=utf-8

FILE

    /Users/DoraZhang/Documents/p_testcase/test25.py

FUNCTIONS

    break_words(stuff)

        This function will break up words for us.

    

    print_first_and_last(sentence)

        Prints the first and last words of the sentence.

    

    print_first_and_last_sorted(sentence)

        Sorts the words then prints the first and last one.

    

    print_first_word(words)

        Prints the first word after popping it off.

    

    print_last_word(words)

        Prints the last word after popping it off.

    

    sort_sentence(sentence)

        Takes in a full sentence and returns the sorted words.

    

    sort_words(words)

        Sorts the words.

(END)

import module 是把整个模块引入

from module import * 是把模块内的所有函数引入

区别在于:

第一种引入在调用函数时 需要module.function()

第二种引入在调用函数时 可以直接function()

问题来了:引入的不同模块命名有冲突怎么办?

Answer:使用import,避免使用from module import **

python中可以直接进行字符串的比对,像“test” == “test”, True。

python中用!=表示“不等于”

False True 第一个字母大写。

相似语句粘贴时,记得回查不同的部分是否已正确修改,不要粘贴之后不检查。

python的规则里,一行以冒号“:”结尾,它接下来的内容就应该有缩进。

174 of 365

这两天悟到一个道理:

遇到别人的反问还有质疑时,不要急于反思自己,责怪自己。

立足第三方,思考当前的情形,是否真的是原因在你。

有时候,对方可能受个人因素,个人经历的局限,产生质疑。

冷静之后,再去反思自己。