当我们需要查看某个很大的文件时,查看全部内容会非常耗时,还会因为文件过大,查看起来非常的不方便,下面我们介绍一下Linux的几种文件查看方式
查看 catalina.out 文件后100行
tail -n 100 catalina.out
cat 命令为从首行显示到尾行,一次展示文件全部内容,当文件比較大时,来不及看就翻屏过了。tac效果与cat相似,是从尾行显示到首行;
cat 是 concatenate(连接、连续)的简写。
cat file1 file2 > file3 --将文件file1 和 file2 的内容合并到 file3
Usage:
cat [OPTION]... [FILE]...
Options:
| key | value |
|---|---|
| -n, --number | 显示行号;输出所有行的数量 |
| -b, --number-nonblank | 显示非空行号;非空的输出行数,覆盖-n |
| -s, -squeeze-blank | 抑制重复的空行输出(连续重复的空行显示为一行) |
| -E, --show-ends | 在每一行的末尾显示$。 |
| -T, --show-tabs | 显示TAB字符为^I |
| -A, --show-all | 相当于-vET,用于列出所有隐藏符号,包括回车符($)、Tab 键(^I)等 |
| -e | 相当于 -vE |
| -t | 相当于 -vT |
| -u | 忽略 |
| --v, --show-nonprinting | 使用^和M-符号,LFD和TAB除外 |
| --help | 显示此帮助并退出 |
| --version | 输出版本信息并退出 |
Tips:cat 命令用于查看文件内容时,不论文件内容有多少,都会一次性显示。如果文件非常大,那么文件开头的内容就看不到了。不过 Linux 可以使用PgUp+上箭头组合键向上翻页,但是这种翻页是有极限的,如果文件足够长,那么还是无法看全文件的内容。因此,cat 命令适合查看不太大的文件。
Usage:
tac [OPTION]... [FILE]...
Options:
| key | value |
|---|---|
| -b, --before | 将分隔符放在前面而不是后面 |
| -r, --regex | 将分隔符解释为一个正则表达式 |
| -s, --separator=STRING | 使用 STRING 作为分隔符而不是换行符 |
| --help | 显示此帮助并退出 |
| --version | 输出版本信息并退出 |
tail 命令显示文件结尾内容,默认显示文件最后
10行; head 命令显示文件开头内容,默认显示文件开头10行;
tail Usage:
tail [OPTION]... [FILE]...
head Usage:
head [OPTION]... [FILE]...
Options:
| key | tail | head |
|---|---|---|
| -c, --bytes=[+]NUM | 输出最后的 NUM个字节;+NUM,从 NUM个字节开始输出 |
打印开头的 NUM字节;-NUM,打印文件除最后 NUM个字节的所有内容 |
| -n, --lines=[+]NUM | 输出最后的 NUM行;+NUM,从 NUM行开始输出 |
打印开头的 NUM行;-NUM,打印文件除最后 NUM行的所有内容 |
| -f, --follow[={name|descriptor}] | 随着文件的增长,输出附加的数据;没有选项参数意味着 "descriptor" | X |
| -F | 与 --follow=name --retry 相同 | X |
| --retry | 在文件无法访问的情况下继续尝试打开该文件 | X |
| -s, --sleep-interval=N | 与-f一起使用,睡眠时间大约为N秒 (默认为1.0)。 至少每隔N秒检查一次 | X |
| --pid=PID | 与-f使用,在进程ID、PID死亡后终止 | X |
| -q, --quiet, --silent | 不输出文件名的标题(默认) | 不打印提供文件名的标题 |
| -v, --verbose | 总是输出文件名的头文件 | 总是打印文件名的标题 |
| -z, --zero-terminated | 行的分隔符是NUL,不是换行符 | 行的分隔符是NUL,不是换行符 |
| --help | 显示此帮助并退出 | 显示此帮助并退出 |
| --version | 输出版本信息并退出 | 输出版本信息并退出 |
Tips:
tail -num 等价于 tail -n num, head 也一样;b 512, kB 1000, K 1024, MB 1000*1000, M 1024*1024,GB 1000*1000*1000, G 1024*1024*1024, 以此类推,T、P、E、Z、Y。KiB=K,MiB=M,以此类推。less 与 more命令相似,都是分页显示文件全部内容。
Usage:
more [options] [file]...
Options:
| key | value |
|---|---|
| -d, --silent | 显示帮助而不是响铃 |
| -f, --logical | 计算逻辑而不是屏幕行数 |
| -l, --no-pause | 禁止在表格输入后暂停。 |
| -c, --print-over | 不滚动,显示文本和干净的行尾 |
| -p, --clean-print | 不滚动,清洁屏幕并显示文本 |
| -s, --squeeze | 将多个空行挤压成一行 |
| -u, --plain | 抑制下划线和加粗。 |
| -n, --lines [number] | 每个屏幕的行数 |
| -[number] | 与-lines相同 |
| +[number] | 显示从行号开始的文件 |
| +/[pattern] | 显示从模式匹配开始的文件 |
| -h, --help | 显示此帮助 |
| -V, --version | 显示版本 |
常用交互命令
| 交互指令 | 功能 |
|---|---|
| h | ? | 交互命令帮助 |
| q | Q | 退出 more |
| v | 在当前行启动系统预设文本编辑器 |
| = | 显示当前行的行号 |
| :f | 显示当前文件的文件名和行号 |
| !<命令> 或 :!<命令> | 在子Shell中执行指定命令 |
| 回车键 | 向下移动一行 |
| 空格键 | 向下移动一页 |
| Ctrl+l | 刷新屏幕 |
| ' | 转到上一次搜索开始的地方 |
| Ctrf+f | 向下滚动一页 |
| . | 重复上次输入的命令 |
| /字符串 | 搜索指定的字符串 |
| d | 向下移动半页 |
| b | 向上移动一页 |
查看开头或结尾内容
tail -n 200 catalina.out # 输出 最后200行内容
tail -n 2b catalina.out # 输出 最后 2 * 512行内容
head -n 100 catalina.out # 输出 开头100行内容
head -n b catalina.out # 输出 开头 512行内容
排除开头或结尾内容
tail -n +200 catalina.out # 输出 开头200行 以后的内容,即从200行开始打印
head -n -100 catalina.out # 输出 最后100行 以前的内容, 即打印到最后100行为止
Tips: tail 和 head 都支持乘数后缀(b, K ,M 等等)
查看显示行号
cat -n catalina.out # 显示所有行号(包括空行)
cat -b catalina.out # 显示所有行号(但不包括空行)
less -N catalina.out # 显示所有行号(包括空行)
nl [-ba] catalina.out # 显示所有行号(包括空行)
nl -bt catalina.out # 显示所有行号(但不包括空行)
实时查看文件内容
tail -f catalina.out
less catalina.out --> F
合并文件
cat file1 file2 > file3
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A
我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只