admin管理员组

文章数量:1530516

2024年7月22日发(作者:)

UltraEdit高级教程

UltraEdit 是一套功能强大的文本编辑器,可以编辑文字、Hex、ASCII

码,可以取代记事本,内建英文单词检查、C++及VB 语法加亮,可

同时编辑多个文件,而且即使开启很大的文件速度也不会慢。软件附

有 HTML Tag 颜色显示、搜寻替换以及无限制的还原功能。UltraEdit

支持二进制和16进制编辑,所以还可以用来修改EXE 或DLL 文件。

本文面向有一定UltraEdit 使用经验的用户,介绍UltraEdit 中的

高级功能,这些功能往往被大多数使用者忽视,灵活地使用这些功能

将极大的提高工作效率,达到事半功倍的效果。要使用本教程所介绍

的所有功能,需要UltraEdit 12.00以上版本或UEStudio 06.10以

上版本。

列模式

列模式是讲到UltraEdit 不得不说的一个强大功能。列模式能让您

按列选取和编辑数据,而一般编辑器只能按行选择数据。

进入列模式的方法:

使用快捷键Alt+C ,或者使用菜单 列->列模式 ,见下图

进入列模式后,通过按下键盘上的SHIFT键和方向键来选择多列,选

中后的效果见下图,光标变成了多列光标。

此时在键盘上敲入字符的时候,被选中的每一列 都会出现相同的字

符,比如按下键盘上的”/”两次,效果见下图。这个例子实际上在

编程的时候经常用到,当需要注释一段代码的时候,不必一行一行的

注释,采用列模式能减少很多重复的工作。

插入 / 填充列:

以下图的书目文件为例,文件中缺少出版社的信息,而这些书的出版

社都为”电子工业”,使用插入 /填充列可以方便地完成这个工作。

首先在列模式下选择要填充的列,选择菜单 列->插入 /填充列 ,然

后出现一个对话框,在这里填写要插入 的文字后点”确定”。

确定后,刚才选中的每一列 上都出现了”电子工业”四个字。

在这里也许您会问,为什么不用上面的方法,选中多列后直接在键盘

上敲入”电子工业”四个字?其实如果敲入的是英文字母或字符是

没有问题,当在列模式下敲入的是汉字的时候会出现乱码,因此可以

用插入 /填充列这个功能来解决这个问题。

讲到这里是否已感觉到UltraEdit 的强大,接着往下看,您会发现

UltraEdit 能做很多Excel的工作,甚至Excel完成不了的工作。

插入 号码:

同样以上面的书目文件为列,我们希望给每行前面加一个行号。

首先进入列模式,选中第一列 ,也就是”书名 = “这几个字前的那

一列 ,选择菜单 列->插入 号码 。如下图:

点击后进入以下插入 号码的选项框,我们要插入 的是行号,因此起

始数字为1,增量也是1,为了显示得整齐一些我们把列首补零也勾

上。

按上图的设置设好后,点”确定”,效果见下图,插入 行号的工作

就完成了。

上面说了UltraEdit 能完成很多Excel的工作,下面就看看如何按

列求和。

列 / 选择统计:

在上面书目文件中,有一个价格列标名了每本书的价格,若想知道这

些书的总价钱,很简单:

首先在列模式下选中这些价格,然后点菜单 列-> 列/选择统计

在出现的对话框中点一下统计,即可看到统计结果,见下图。这个对

话框中的”忽略数据中的字符”填的是”,”,这是保证您要统计的

数据以千分位分隔的时候也能正常统计,比如这样的数字

“24,501″。

或许您有一个疑问,上面我们处理的文件,它的格式都很工整,但往

往我们拿到的初始数据都是不工整的。遇上下图的数据,我们想统计

这些书的总价钱的时候怎么办?(第3个字段表示价格)下面介绍转

换到固定列功能来解决这个问题。

转换到固定列:

通过菜单 列->转换到固定列 将弹出以下对话框,根据文件的情况

设置分隔字符,本例中我们的分隔符是TAB制表符,输入”^t”,其

它设置保持默认值,然后点”扫描”按钮,扫描后的结果显示在最下

面的框中,本例中为”10,27,3,8″,表示第一个字段(序号)要占

10列,第二个字段(书名)占27列,以此类推。

通常我们不需要改变扫描后的结果,直接点转换就能得到下图的效

果,这样无论是做统计,还是做接下来讲到的排序,都很方便。

排序 (Sort)

排序是UltraEdit 提供的非常实用的一个功能,也许您会觉得用

Excel更方便,但别忘了Excel只能支持65535行数据,而UltraEdit

处理上百万行的数据也不成问题,功能决不逊色于Excel。

下面用一个简单的文件为例,讲述如何排序,见下图,这个是一个商

品表,最后一列 是价格,我们要以价格来排序文件。

首先进入菜单 文件->排序->高级排序/选项 ,见下图

弹出如下的排序选项对话框:

排列顺序 :可以选择是升序还是降序

删除重复项 :可以将文件中一模一样的行删除,只保留一行。(想

想用Excel怎么去除重复项)

数字排序 :当要排序的列是数字,并且关心它的实际大小时需要勾

选这一项,下面的示例将说明这个问题。

排序列 :一共可以设置4个列,通过起始列和结束列来指定。

假设我们要把这个文件按价格升序排列,在这个对话框中选择升序,

因为我们关心数值的实际大小,所以勾选数字排序,通过标尺我们确

定价格这一字段从65列起到71列结束。设置好后点”排序”按钮,

效果如下图。(如果您看不到标尺,可能通过菜单 视图->显示标尺 来

显示)

如果没有勾选数字排序,将会出现下图所示的结果,可以看出它是按

字符的ASCII码在大小来排序的,而不是数值的真正大小。

正则表达式搜索与替换

先来解释一下什么叫正则表达式:相信您一定使用过Windows或Dos

下用于文件查找的通配符,也就是*和?。如果您想查找某个目录下的

所有的 Word文档的话,您很自然地会搜索”*.doc”。在这里,”*”

会被解释成任意的字符串。和通配符类似,正则表达式也是用来进行

文本匹配的工具,只不过比起通配符,它能更精确地描述您的需求。

当然,代价就是更复杂,例如搜索doc为扩名的文件,正则表达式

为”.*.doc”。别看它复杂了很多,但正则表达式几乎能满足您的

一切搜索需求。比如您可以编写一个正则表达式,用来查找所有以0

开头,后面跟着2-3个数字,然后是一个连字号”-”,最后是7或 8

位数字的字符串(像************或************)。

在UltraEdit 中,正则表达式被很好地支持,目前的版本中一共支

持三种,UltraEdit 风格正则表达式、Unix风格正则表达式和Perl

兼容正则表达式,本文介绍Perl兼容正则表达式,这是一条被广泛

使用的正则表达式,绝大多数的编程语言都支持这种表达式。

要使用Perl兼容正则表达式,需要在UltraEdit 中做一下设置。点

击菜单 高级->配置 ,出现下图的对话框,在左侧选中”正则表达式

引擎”,右边勾选”Perl兼容正则表达式”。

正则表达式语法:

由于本文的重点不在正则表达式语法方面,这里只做简单介绍。

元字符:

元字符 说明

. 匹配除换行符以外的任意字符

s 匹配任意的空白符()

d 匹配数字

b 匹配单词的开始或结束

w 匹配字母或数字或下划线或汉字

W 匹配任意不是字母,数字,下划线,汉字的字符

S 匹配任意不是空白符的字符

D 匹配任意非数字的字符

^ 匹配行首

$ 匹配行尾

字符转义

B 匹配不是单词开头或结束的位置

如果您想查找元字符本身的话,需要使用””来转意。例如”.”代

表除换行以外的任意字符,如果您想搜索”.”这个字符的话,需要

这样使用”.”。

重复

语法 说明

* 重复零次或更多次

+ 重复一次或更多次

重复零次或一次

{n} 重复n次

{n,} 重复n次或更多次

{n,m} 重复n到m次

字符集

若要匹配aeiou五个字符中的任意一个,可以表示成[aeiou]。再如

[0-9]表示0到9之间的任意一个数字,它的含义和元字符中的d实

际上是一样的。

反意

如果要匹配非a则[^a],除aeiou五个字母之外的表示成[^aeiou],

贪婪与止贪

设有字符串dvea deb cadefb oipi,正则表达式a.*b,表达式的意

思是匹配由a开始中间包含任意多个字符并以b结尾,这个表达式匹

配出来的结果是a deb cadefb ,而不会是a deb ,我们称这种匹配

为贪婪匹配,因为它匹配了尽可能多的字符。要防止这种贪婪匹配,

使用”?”,把上面的表达式写成a.*?b的话,匹配出来的结果就是

a deb 了。

UltraEdit 中的正则表达式查找

我们以一个html为例,希望搜索一个

    Html标记的内容。首先

    要明确要搜索的字符串的特征:以结尾,中间包含任意

    字符(包括换行),于是表达式可以写成。在这里[Ss]

    表示空白和非空白(即所有字符),随后的*表示任意多个,?表示非

    贪婪搜索。

    确定表达式后按下键盘上的Ctrl+F 在弹出的查找对话框中输入表达

    式,并且勾选”正则表达式”,点”查找下一个”即可看到搜索的效

    果见下图。

    UltraEdit 中的正则表达式替换

    在UltraEdit 中正则表达式不但可以用于查询还能用于替换,这里

    介绍一种复杂的替换。以下图所示的一个文件为例,文中有很多日期,

    都是这样的格式dd/mm/yyyy,我们希望把他替换成yyyy-mm-dd的格

    式。

    既然是替换,那么必需先查到目标串,用d表示数据,月和日都一

    位或两位数据组成,正则表达式表示为d{1,2},年份都四个数字表

    示为 d{4},加上中间的分隔符/,整个日期串可以表示为

    d{1,2}/d{1,2}/d{4}。我们替换的目标是要把最后的年份放到第

    一位去,因此还需要这个搜索能返回各个部分的值,在Perl正则表

    达式中用()可以返回搜索串中的值,并用$1表示第一个括号中的值,

    因此我们加上3个括号表达式变成 (d{1,2})/(d{1,2})/(d{4}),

    那么$1表于日,$2表示月,$3表示年。说到这里要达到我们的目标

    就很简单了。

    按下键盘上的Ctrl+R 调出替换对话框,查找内容为

    (d{1,2})/(d{1,2})/(d{4}),替换为$3-$2-$1,记得勾上”正则

    表达式”。

    填好后”全部替换”,替换后的效果见下图。

    常用的正则表达

    行首空格: ^s+

    行尾空格:s+$

    IP地址:[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}

    正整数: ^[1-9]d*$

    负整数: ^-[1-9]d*$

    远程文件直接编辑

    对于刚接触Linux的人来说,要编辑Linux上的文件是一件很痛苦的

    使用,Linux上的VI编辑器可不像UltraEdit 这么好用,在没有

    UltraEdit 前也许您只能把文件下载回来编辑好后再传上来,有了

    UltraEdit 的话不需要这么麻烦了,他直接打开远程机器上的文件,

    保存后自动上传到远程服务器。

    使用这个功能很简单,点菜单 文件->FTP/Telnet->从FTP打开 ,

    如下图。

    如果您已经配置好了FTP帐号,那么点”浏览站点”就可以看到远程

    机器上的文件,选中要编辑的文件点打开就可以在UltraEdit 中编

    辑了。见下图。

    如果您是第一次使用这个功能,那么可以点上图中的”帐号”按钮,

    将会弹出下图所示的帐户管理器,通过简单的设置即可完成帐号的增

    加。

    注意 :不建议使用该功能编辑系统核心文件,保存的时候如果出现

    网络故障容易导致文件丢失。

    冻结窗口

    实现上UltraEdit 中并没有冻结窗口这个概念,之所以这么中是因

    为UltraEdit 可以实现类似Excel的冻结窗口的功能。在Excel中

    我们常用这个功能来固定表头,这样上下滚动的时候可以保持表头不

    动。

    UltraEdit 中可以实际固定左侧列,滚动水平条的时候只有右边动。

    例如一个书目文件,第一列 是书名,而价格这一列 在最后,中间夹

    着很多内容,当把价格这一类滚动到视图中间的时候却看不到书名。

    因此我们想把书名这一列 固定下来,在滚动水平条的时候固定不动,

    先要设置一个列标记,点菜单 视图->设置列标记 ,见下图。

    在出现的设置列标记对话框中,我们勾上第一行,并设置值为41,

    41是书名的结束列。如下图。

    设好后,点”确定”,可以看到在41列的地方多了一条竖线,这个

    时候再点菜单 视图->不滚动标记1左侧 ,这样41列前的内容在水

    平条滚动的时候不会变,可以把后面的内容滚到前面来,见下图。

    语法加亮

    语法加亮是UltraEdit 的一个突出亮点,它能像各种语言的IDE开

    发环境一样,对各种语法的关键字着色。UltraEdit 通过一个叫

    wordfile的文件来定义各种语言的着色规则。通过添加语法规则即

    可增加UltraEdit 的识别能力。

    默认安装后的UltraEdit 不支持Oracle的SQL语法着色,下面举例

    如何让UltraEdit 识别Oracle的SQL脚本并对关键字着色。

    首先打开wordfile定义文件,点菜单 高级->配置 ,在左侧找到”

    语法加亮”,点右边的”打开”按钮即可打开wordfile文件。

    到官方网站下载Oracle的语法定义文件,官方提供了上百种语法的

    定义文件,可以根据需要下载,路径为

    dit .com/downloads/#wordfiles 。

    把下载回来的文件粘在wordfile的结尾保存一下就行了。如下图

    但这里要注意一下,下回来内容的开头有一个/L后面有个数字,这

    个数据需要根据自己的情况改变一下。这是一个编号,不能和

    wordfile已有的编号重复,并且不能大于20。您可以通过以下方法

    确定这个编号,点一下工具栏上的”查看方式”按钮,

    然后弹出下图的菜单,红色框内语言15到语言20都是目前系统没有

    用到的编号,因此在这里我们可以把这个编号改成15。

    保存后,当我们再次打开Oracle的SQL脚本的时候,语法中的关键

    字已经会自动着色了。

    Tip 1: 如何去掉所编辑文本中包含特定字符串的行?

    这则技巧是在UltraEdit的帮助文件里提到.CTRL+R 调出来替换

    (Replace)窗口,选中"使用正则表达式";然后用查找 %*你的字符串

    *^p 替换成空内容即可.如,我当前有个文本文件,需要去掉所有包

    含 / 这个字符串的行,查

    找 %*/*^p 替换成空即可.注意,^p 是

    DOS 文件类型的换行符.如果是 Unix 类型文件,则用 ^n.

    Tip 2: 如何在行末添加特定字符,比如逗号?

    有了上面的经验(其实我第一次是从同事那里学到 的),CTRL+R 调出

    来替换(Replace)窗口,选中"使用正则表达式".然后可以查找 ^p(或

    者^n,如果是Unix 文件),用 ,^p(或者,^n)进行"全部替换"即可.补

    充一点,如果是 MAC(Apple) 类型文件,则换行符号为 ^r .

    Tip 3: 如何删除空行?

    看来,正则表达式需要学习一下喽.

    Tip 4: 编辑文件如何加入时间戳 ?

    F7 快捷键即可.你试试看?

    参考上面两个例子,查找 ^p$ 然后替换为空即可.

    Tip 5: 为何拷贝(Copy)/粘贴(Paste)功能不能用了?

    不怕大家笑话,我有几次使用 UltraEdit 的过程中发现拷贝与粘贴

    的内容是不匹配的.不知所以然,干脆重新启动了笔记本.今天翻看

    手册才恍然大悟:UltraEdit有10个剪切板 (clipboard),分别用

    Ctrl+0 - Ctrl+9 切换. Ctrl+0 是 Windows 的,其他则为用户

    自定义的.我在使用的过程中错调用了 CTRL+n, 结果内容就有问题

    了.你遇到过没?

    Tip 6: 即使是打开小文件也有迟延?

    这是我遇到过的问题.每次打开文件的时候总有几秒钟的耽搁. 我

    的机器性能可不算差.怎么回事? 网络打印机搞得鬼! 打开"高级

    "->"设置"->"编辑器"->"高级",看看是不是选中了"载入/恢复打印

    机设置"?如果是的话,去掉(不同的版本/汉化与否可能该位置所在有

    差别).

    Tip 7: 删除当前行内容 CTRL+e

    本文标签: 文件时候下图使用字符