引言:本文整理自vbaexpress.com论坛,有兴趣的朋友可以研阅。...Q:我在列D的单元格中存放着一些数据,每个单元格中的多个数据使用换行分开,列E是对列D中数据的相应描述,我需要在列E的单元格中查找是否存在列D中的数据,并将找到的数据标上颜色,如下图1所示。 ?...A:实现上图1中所示效果的VBA代码如下: Sub ColorText() Dim ws As Worksheet Dim rDiseases As Range Dim rCell...End If Loop Next iDisease Next rCell End Sub 代码中使用Split函数以回车符来拆分单元格中的数据并存放到数组中...,然后遍历该数组,在列E对应的单元格中使用InStr函数来查找是否出现了该数组中的值,如果出现则对该值添加颜色。
学习Excel技术,关注微信公众号: excelperfect Q:如下图1所示,在工作表列A中有很多数据(为方便表述,示例中只放置了9个数据),这些数据中有很多重复数据,我想得到重复次数最多的数据是那个...,示例中可以看出是“完美Excel”重复的次数最多,如何获得这个数据?...在上面的公式中: MATCH($A$1:$A$9,$A$1:$A$9,0) 在单元格区域A1:A9中依次分别查找A1至A9单元格中的数据,得到这些数据第1次出现时所在的行号,从而形成一个由该区域所有数据第一次出现的行号组组成的数字数组...MODE函数从上面的数组中得到出现最多的1个数字,也就是重复次数最多的数据在单元格区域所在的行。将这个数字作为INDEX函数的参数,得到想应的数据值。...,则上述公式只会获取第1个数据,其他的数据怎么得到呢?
学习Excel技术,关注微信公众号: excelperfect 这里的应用场景如下: “在工作表Sheet1中存储着数据,现在想要在该工作表的第O列至第T列中搜索指定的数据,如果发现,则将该数据所在行复制到工作表...Sheet2中。...用户在一个对话框中输入要搜索的数据值,然后自动将满足前面条件的所有行复制到工作表Sheet2中。” 首先,使用用户窗体设计输入对话框,如下图1所示。 ?...Application.ScreenUpdating = False '赋值为工作表Sheet1 Set wks = Worksheets("Sheet1") With wks '工作表中的最后一个数据行...("O2:T"& lngRow) '查找的数据文本值 '由用户在文本框中输入 FindWhat = "*" &Me.txtSearch.Text & "*
中任意一个,就可以将光标移动到最底下那一行,进入底线命令模式(也称为指令列命令模式)。...可以让你重复的找到一些你搜寻的关键词! 替换 :n1,n2s/word1/word2/g在第 n1 与 n2 行之间寻找 word1 这个字符串,并将该字符串取代为 word2 !...:w [filename]将编辑的数据储存成另一个档案(类似另存新档) :r [filename]在编辑的数据中,读入另一个档案的数据。...在 vi 中設定一下行號; 6. 移動到第 43 列,向右移動 59 個字元,請問你看到的小括號內是哪個文字? 7. 移動到第一列,並且向下搜尋一下『 gzip 』這個字串,請問他在第幾列? 8....在第一列新增一列,該列內容輸入『I am a student...』; 15. 儲存後離開吧!
光标移动到非空格符的上一列 n 那个 n 表示『数字』,例如 20 。...复制光标所在的向下 n 列,例如 20yy 则是复制 20 列(常用) y1G 复制游标所在列到第一列的所有数据 yG 复制游标所在列到最后一列的所有数据 y0 复制光标所在的那个字符到该行行首的所有数据...那么原本的第 20 行会被推到变成 30 行。 (常用) J 将光标所在列与下一列的数据结合成同一列 c 重复删除多个数据,例如向下删除 10 行,[ 10cj ] u 复原前一个动作。...[Esc] 退出编辑模式,回到一般模式中(常用) 第三部份:一般模式切换到指令列模式的可用的按钮说明 指令列的储存、离开等指令 :w 将编辑的数据写入硬盘档案中(常用) :w!...:w [filename] 将编辑的数据储存成另一个档案(类似另存新档) :r [filename] 在编辑的数据中,读入另一个档案的数据。
现在,只是在单元格区域F13:F36中输入公式: =IF(INDEX(C3:C10,B13)=C13,1,0) 结果由0和1组成的一列数字,基于单元格区域C3:C10中指定的颜色,每个切片数字都有2个0...我们需要另一个公式来让我们只显示可见的切片编号。...在单元格区域E13:E36中输入公式: =IF(F13=1,B13,"") 现在选择饼图切片(全部或一个),拖动紫色高亮区域的任意角使其占据一列,然后拖动紫色高亮的边缘使其包括“标签”列。...你可以选择下方的数据区域并将其拖到图表的一侧,甚至可以将其剪切并粘贴到另一个工作表上,而是将图表移近它间接反映的数据区域,如下图12所示。 ?...图12 当在工作表中更改每个切片的颜色时,图表也相应地反映了该变化,如下图13所示。 ? 图13 再次修改工作表中的颜色,图表也相应更新,如下图14、图15所示 ? 图14 ?
l:右移 M:光标移动中间行 L:光标移动到屏幕最后一行行首 G:移动到指定行,行号 -G 在命令行中输入 vi +26 samp.txt 命令直接打开文件到达...26 行,在 vi 编辑器中也可以输入 :26 跳转到 26 行 {:按段移动,上移 }:按段移动,下移 Ctr-d:向下翻半屏 Ctr-u:向上翻半屏...这是个点,重复上一次操作的命令 文本行移动 >>:文本行右移 <<:文本行左移 1.6 复制剪切粘贴 可视模式(选择文本) v 按字符移动,选中文本 V 按行移动 ctrl+v 按列选择...突出显示当前行 set expandtab " 空格代替制表符 set showmatch " 光标遇到圆括号、方括号、大括号时,自动高亮对应的另一个圆括号...、方括号和大括号 set ruler " 在状态栏显示光标的当前位置(位于哪一行哪一列) set guifont=Consolas:h15 " 设置字体和字体大小
>移动到当前数据区域的边缘:CTRL+ 箭头键 移动到行首:HOME 移动到工作表的开头:CTRL+HOME 移动到工作表的最后一个单元格。...:F6 移动到被拆分的工作簿中的上一个窗格:SHIFT+F6 滚动并显示活动单元格:CTRL+BACKSPACE 显示“定位”对话框:F5 显示“查找”对话框:SHIFT+F5 重复上一次“查找”操作:...向上或向下滚动一行:上箭头键或下箭头键 向左或向右滚动一列:左箭头键或右箭头键 4>Excel快捷键之用于预览和打印文档 显示“打印”对话框:CTRL+P 在打印预览中时: 当放大显示时,在文档中移动...:CTRL+PAGE UP,END, SHIFT+ENTER 7>Excel快捷键之用于在工作表中输入数据 完成单元格输入并在选定区域中下移:ENTER 在单元格中折行:ALT+ENTER 用当前输入项填充选定的单元格区域...CTRL+0(零) 取消隐藏列:CTRL+SHIFT+)右括号 9>Excel快捷键之编辑数据 编辑活动单元格并将插入点放置到线条末尾:F2 取消单元格或编辑栏中的输入项:ESC 编辑活动单元格并清除其中原有的内容
w: 前移一个单词,光标停在下一个单词开头; W: 移动下一个单词开头,但忽略一些标点; e: 前移一个单词,光标停在下一个单词末尾; E: 移动到下一个单词末尾,如果词尾有标点,则移动到标点; b:...I: 在当前行第一个非空字符前插入; gI: 在当前行第一列插入; a: 在光标后插入; A: 在当前行最后插入; o: 在下面新建一行插入; O: 在上面新建一行插入; :r filename在当前位置插入另一个文件的内容...j的含义是grep结束后,结果停在第j项,默认是停在第一项。 vimgrep前面可以加数字限定搜索结果的上限,如 :1vim/pattern/ % 只查找那个模式在本文件中的第一个出现。...n ctrl+w _ – 当前窗口的高度设定为n行。 ctrl+w 一列。也可以用n减少n列。 ctrl+w > –当前窗口增宽一列。也可以用n增宽n列。...:set ff,显示当前文件的格式。 在vimrc中添加set fileformats=unix,dos,mac,让vim自动识别文件格式。
2. vim常用命令 2.1 一般模式中的命令 2.1.1 光标移动 命令 说明 h,← 光标左移一个字符 j,↓ 光标下移一个字符 k,↑ 光标上移一个字符 l,→ 光标右移一个字符 n[h,j,k,...个字符 aa a Ctrl + f,[PgDn] 屏幕向下移动一页 Ctrl + b,[PgUp] 屏幕向上移动一页 Ctrl + d 屏幕向下移动半页 Crtl + u 屏幕向上移动半页 + 光标移动到非空格符的下一列...- 光标移动到非空格符的上一列 n n表示数字,再按下空格键光标向右移动n个字符 0,[Home] 光标移动到第一个字符 $,[End] 光标移动到最后一个字符 H 光标移动到屏幕第一行第一个字符...word 向光标之前查找”word“ n 重复前一个查找的动作 N 反向重复前一个查找的动作 :n1,n2s/word1/word2/g n1和n2为数字在n1行和n2行之间查找word1,并替换为word2...强制保存并离开 ZZ 若文件没有改动,则不保存离开,如果文件有改动,则保存后离开 :w[filename] 将文件另存为filename :r[filename] 在光标处插入另一个文件的数据 :n1,
而且写文件、查找翻页什么的 比我用鼠标快多了,那熟练的快捷键看的我一愣一愣的 ---- 光标移动: h或退格: 左移一个字符; l或空格: 右移一个字符; j: 下移一行; k: 上移一行; gj: 移动到一段内的下一行...w: 前移一个单词,光标停在下一个单词开头; W: 移动下一个单词开头,但忽略一些标点; e: 前移一个单词,光标停在下一个单词末尾; E: 移动到下一个单词末尾,如果词尾有标点,则移动到标点; b:...后移一个单词,光标停在上一个单词开头; B: 移动到上一个单词开头,忽略一些标点; (: 前移1句。...插入: I: 在当前行第一个非空字符前插入; gI: 在当前行第一列插入; a: 在光标后插入; A: 在当前行最后插入; o: 在下面新建一行插入; O: 在上面新建一行插入; :r filename...在当前位置插入另一个文件的内容。
操作数据帧可能很快会成为一项复杂的任务,因此在Pandas中的八种技术中均提供了说明,可视化,代码和技巧来记住如何做。 ?...初始DataFrame中将成为索引的列,并且这些列显示为唯一值,而这两列的组合将显示为值。这意味着Pivot无法处理重复的值。 ? 旋转名为df 的DataFrame的代码 如下: ?...包含值的列将转换为两列:一列用于变量(值列的名称),另一列用于值(变量中包含的数字)。 ? 结果是ID列的值(a,b,c)和值列(B,C)及其对应值的每种组合,以列表格式组织。...Stack 堆叠采用任意大小的DataFrame,并将列“堆叠”为现有索引的子索引。因此,所得的DataFrame仅具有一列和两级索引。 ? 堆叠名为df的表就像df.stack()一样简单 。...因此,它接受要连接的DataFrame列表。 如果一个DataFrame的另一列未包含,默认情况下将包含该列,缺失值列为NaN。
指令列命令模式 (command-line mode) 在一般模式当中,输入『 : / ? 』三个中的任何一个按钮,就可以将光标移动到最底下那一列。...0 或功能键[Home] 这是数字『 0 』:移动到这一列的最前面字符处 (常用) $ 或功能键[End] 移动到这一列的最后面字符处(常用) H 光标移动到这个屏幕的最上方那一列的第一个字符 M 光标移动到这个屏幕的中央那一列的第一个字符...L 光标移动到这个屏幕的最下方那一列的第一个字符 G 移动到这个文件的最后一列(常用) nG n 为数字。...(常用) J 将光标所在列与下一列的数据结合成同一列 c 重复删除多个数据,例如向下删除 10 列,[ 10cj](常用) u 复原前一个动作。(常用) [Ctrl]+r 重做上一个动作。...:w [filename] 将编辑的数据储存成另一个文件(类似另存新档) :r [filename] 在编辑的数据中,读入另一个文件的数据。
中文版 复制一份网上的快捷键: 移动光标: h或左方向键:光标向左移动一个字符 j或下方向键:光标移到下一行 k或者上方向键:光标向上移动一行 l或者右方向键:光标向右移动一个字符 +: 光标移动到非空格符的下一列...-: 光标移动到非空格符的上一列 n: 按下数字再按space,光标向右移动n个字符 0 :移动到这一行的第一个字符处 $:移动到这一行的最后一个字符处 翻页: ctrl+f:...(常用) 命令模式 :w 将编辑的数据写入硬盘文件中(保存) :w!...强制保存后退出(常用) :w [filename] 将编辑数据保存为另一个文件(另存为) :r [filename] 在编辑的数据中,读入另一个文件的数据,并将filename这个文件的内容加到光标所在行的后面...第2节 操作符与重复 ? 第3节 复制粘贴 ? 第4节 搜索 ? 第5节 标记与宏指令 ? 第6节 各种动作 ? 第7节 各种命令
w: 前移一个单词,光标停在下一个单词开头; W: 移动下一个单词开头,但忽略一些标点; e: 前移一个单词,光标停在下一个单词末尾; E: 移动到下一个单词末尾,如果词尾有标点,则移动到标点; b:...(: 前移1句。 ): 后移1句。 {: 前移1段。 }: 后移1段。...也可以,不过精确到列,而'‘精确到行 。如果想跳转到更老的位置,可以按C-o,跳转到更新的位置用C-i。 `": 移动到上次离开的地方。 `.: 移动到最后改动的地方。 :marks 显示所有标记。...I: 在当前行第一个非空字符前插入; gI: 在当前行第一列插入; a: 在光标后插入; A: 在当前行最后插入; o: 在下面新建一行插入; O: 在上面新建一行插入; :r filename在当前位置插入另一个文件的内容...:[n]r filename在第n行插入另一个文件的内容。 :r !date 在光标处插入当前日期与时间。同理,:r !
但如果是按下P,那么原来的第20行会被变成30行(常用) J 将光标所在行与下一列的数据结合成同一行 c 重复删除多个数据,例如向下删除10行,[10cj] u 复原前一个操作(常用) [Ctrl]+r...一个是复原,另一个则是重做一次。利用这两个功能按键,编辑起来就得心应手。 命令行模式:删除、复制与粘贴 这就是小数点。意思是重复前一个动作。...Esc 退出插入模式,回到命令行模式中(常用) 末行命令模式 key desc :w 将编辑的数据写入硬盘文件中(常用) :w! 若文件属性为“只读”时,强制写入该文件。...将文件还原到最原始的状态 ZZ 若文件没有更改,则不存储离开,若文件已经更改,则存储后离开 :w[filename] 将编辑的数据存储成另一个文件(类似另存新文件) :r[filename] 在编辑的数据中...,读入另一个文件的数据。
,键反射查找上次f{char}所查找的字符 E.查找并手动替换 1.*进行查找,一是光标会跳到下一个匹配项上,二是所有出现这个词的地方都会被高亮显示出来。...用一键移动,另一键执行 二、普通模式 A.把撤销单元切成块 1.在vim中,我们可以自己控制撤销命令的粒度。...C.用面向列块的可视模式编辑表格数据 1....make dir来进行补救 八、用动作命令在文档中移动 A.让手指保持在本位行上 1.h左移一列,l右移一列,j下移一行,k上移一行 2.只用h和l来解决“差一错误”(off-by-one errors...;命令重复f{char}命令,,反向重复F{char}命令 3.t{char},T{char}正/反向移动到下一个{char}所在之处的前一个字符上 E.通过查找进行移动 1.
,据说可以制动更新,不过我使用比较少 F12这个就是集成了ctags, cscope两项功能的函数,只要到你想要生成工程的根目录按F12等待一会后你就能用cscope命令了(这个比较强大) 上述快捷键可以在我上篇中的....vimrc 脚本中更改按照你的习惯F12按键我配置的解析比较全,如果你不需要很全的解析请修改 .vimrc 中的Do_CsTag()配置 不知道如何配置请google, bing, baidu。...: 在代码中光标的移到该串上后 先按 ctrl+/ 然后 c: 查找该函数被调用的位置 d: 查找该函数调用了哪些函数 e: 查找指定的正规表达式 f: 查找指定的文件 g: 查找指定标识符的定义位置...代码行快速移动 浏览模式下 j(下移一行)k(上移一行)h (左移一列)l (右移一列) shift + h (移到行首) shift + l (移到行尾) gg (移动到文件开始) shift+g...(移动到文件最后) shift + f (下翻一屏) shift + b (上翻一屏) 先输入数字 然后 shift + g(直接跳转到该行) w (后移一个字符串) b (前移一个字符串) 5.
0 :光标移动至行首 h :光标左移一格 l :光标右移一格 j :光标下移一行 k :光标上移一行 $+A :将光标移动到该行最后 PageDn :向下移动一页...a :在光标后开始插入 A :在行尾开始插入 i :从光标所在位置前面开始插入 I :从光标所在列的第一个非空白字元前面开始插入 o :在光标所在列下新增一列并进入输入模式...:强制退出Vi程序 :wq :保存修改并退出程序 :set nu :设置行号 0x05:VI列编辑操作 删除列 1)光标定位到要操作的地方 2)CTRL+v 进入“可视 块”模式,选取这一列操作多少行...例如在每一行前都插入"() ": 1)光标定位到要操作的地方 2)CTRL+v 进入“可视 块”模式,选取这一列操作多少行 3)SHIFT+i或者I(大写字母i) 输入要插入的内容 4)ESC 按两次,...会在每行的选定的区域出现插入的内容 列编辑模式非常有用,开发时经常用到properties配置文件,要同时注释多行配置项时,使用列编辑模式非常便捷。
这里需要说明,在我们之前的文章Python批量复制Excel中给定数据所在的行中,也介绍过实现类似需求的另一种Python代码,大家如果有需要可以查看上述文章;而上述文章中的代码,由于用到了DataFrame.append...现有一个Excel表格文件,在本文中我们就以.csv格式的文件为例;其中,如下图所示,这一文件中有一列(也就是inf_dif这一列)数据比较关键,我们希望对这一列数据加以处理——对于每一行,如果这一行的这一列数据的值在指定的范围内...,那么就将这一行复制指定的次数(复制的意思相当于就是,新生成一个和当前行一摸一样数据的新行);而对于符合我们要求的行,其具体要复制的次数也不是固定的,也要根据这一行的这一列数据的值来判断——比如如果这个数据在某一个值域内...随后,我们开始设置重复次数。在这里,我们根据特定的条件,为每个值设定重复的次数。根据inf_dif列的值,将相应的重复次数存储在num列表中。...接下来,我们使用loc函数和np.repeat()函数,将数据按照重复次数复制,并将结果存储在duplicated_df中。 最后,为了对比我们数据重复的效果,可以绘制直方图。
领取专属 10元无门槛券
手把手带您无忧上云