首页
学习
活动
专区
圈层
工具
发布

linux中删除文件的最后N行小总结

-n选项(例如-n -x来打印文件中除最后x行之外的所有行 因此,我们可以使用此选项以直接的方式解决我们的问题: $ head -n -3 rumenz.txt 1 rumenz.com 2 rumenz...但是,如果我们可以颠倒输入文件中的行顺序,问题就会变成从文件中删除前 n 行。一个简单的 sed 单行sed 1,n d可以删除前n行。之后,如果我们再次反转线条,我们的问题就解决了。...tac命令可以反向文件中的行的顺序。...在第一遍中,它会找出文件中的总行数,在第二遍中,我们打印我们想要保留的那些行: $ awk -v n=3 'NR==FNR{total=NR;next} FNR==total-n+1{exit} 1'...在这个过程中,awk命令将当前行号保存到一个名为total的变量中。第一遍后,total变量保存了输入文件中的总行数 FNR==total-n+1{exit} 1:这是第二遍。

10K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    在shell程序里如何从文件中获取第n行

    问: 有没有一种“规范”的方式来做到这一点?我一直在使用 head -n | tail -1,它可以做到这一点,但我一直想知道是否有一个Bash工具,专门从文件中提取一行(或一段行)。...答: 有一个可供测试的文件,内容如下: 使用 sed 命令,要打印第 20 行,可写为 sed -n '20'p file.txt sed -n '20p' file.txt 测试截图如下: 要打印第...8 到第 12 行,则可用命令 sed -n '8,12'p file.txt 如果要打印第8、9行和第12行,可用命令 sed -n '8p;9p;12p' file.txt 对于行数特大的文件...,为了提高处理速度,可采用类似如下命令 sed '5000000q;d' file.txt tail -n+5000000 file.txt | head -1 需要关注处理性能的伙伴可以在上述命令前加上...time 再对大文件进行测试对比。

    4.6K20

    Python将表格文件的指定列依次上移一行

    本文介绍基于Python语言,针对一个文件夹下大量的Excel表格文件,对其中的每一个文件加以操作——将其中指定的若干列的数据部分都向上移动一行,并将所有操作完毕的Excel表格文件中的数据加以合并...由上图也可以看到,需要加以数据操作的列,有的在原本数据部分的第1行就没有数据,而有的在原本的数据部分中第1行也有数据;对于后者,我们在数据向上提升一行之后,相当于原本第1行的数据就被覆盖掉了。...此外,很显然在每一个文件的操作结束后,加以处理的列的数据部分的最后一行肯定是没有数据的,因此在合并全部操作后的文件之前,还希望将每一个操作后文件的最后一行删除。   ...接下来,遍历原始文件夹中的所有文件,并找到文件夹内以.csv结尾的文件;随后,读取这些.csv文件,并将其保存到df中。   ...接下来,我们通过if len(df):判断是否DataFrame不为空,如果是的话就删除DataFrame中的最后一行数据;随后,将处理后的DataFrame连接到result_df中。

    1.9K10

    将Python绘制的图形保存到Excel文件中

    标签:Python与Excel,pandas 在上篇文章中,我们简要地讨论了如何使用web数据在Python中创建一个图形,但是如果我们所能做的只是在Python中显示一个绘制的图形,那么它就没有那么大的用处了...因此,我们只需将Python生成的图形保存到Excel文件中,并将电子表格发送给用户。...根据前面用Python绘制图形的示例(参见:在Python中绘图),在本文中,我们将: 1)美化这个图形, 2)将其保存到Excel文件中。...美化图表 之前我们生成的这个图,尽管对于2行代码来说并不太糟糕,但该图与专业级图相差甚远,所以让我们使它更漂亮。 图1 我们将使用matplotlib修改绘图格式。...生成的图形保存到Excel文件中 我们需要先把图形保存到电脑里。

    7.4K50

    uniq命令 – 去除文件中的重复行

    uniq命令全称是“unique”,中文释义是“独特的,唯一的”。该命令的作用是用来去除文本文件中连续的重复行,中间不能夹杂其他文本行。去除了重复的,保留的都是唯一的,也就是独特的,唯一的了。...我们应当注意的是,它和sort的区别,sort只要有重复行,它就去除,而uniq重复行必须要连续,也可以用它忽略文件中的重复行。...语法格式:uniq [参数] [文件] 常用参数: -c 打印每行在文本中重复出现的次数 -d 只显示有重复的纪录,每个重复纪录只出现一次 -u 只显示没有重复的纪录 参考实例 删除连续文件中连续的重复行...95 Linux 85 Linux 85 [root@linuxcool ~]# uniq testfile test 30 Hello 95 Linux 85 打印每行在文件中出现重复的次数...,且每个纪录只出现一次: [root@linuxcool ~]# uniq -d testfile test 30 Hello 95 Linux 85 只显示没有重复的纪录: [root

    4K00

    文件侠告诉你,Python复制文件的N种姿势!

    项目使用了Python语言,而Python语言拥有强大的API后援团。对于复制文件这样的基础操作,不可能没有现成的API,难道非要写n行代码才能搞定吗?...据我所知,在Python中,可以实现复杂文件功能的函数至少有10个,也许更多。...这里插播一天广告:我即将推出Python API深度详解系列文章,包含了Python中几乎所有的核心API的用法,这些API是Python中的瑰宝,请大家持续关注哦!...区别只是一次性读取了文件中的所有内容,换汤不换药啊!于是,我又启发这位同学,我希望用一行代码搞定,are you ok? ?...三、shutil模块,复制文件函数的集中营 shutil模块中有大量的函数可以用来复制文件,这一节将详细介绍这些函数的用法和差异。

    13.9K41

    将Python的.py文件封装成.exe文件

    今天写了个小脚本,工作原因需要每天重复使用,所以为了方(偷)便(懒),准备将其打包成exe程序,也可以发给没有python环境的同事使用。...cd C:\pip-20.1.1(cd后的路径按照你解压的路径自行填写) python setup.py.install ?...安装完成后需要将pip的安装路径加入系统的path环境中,不然系统不承认。 ? 安装完环境之后,就可以安装用来封装exe的pyinstall了。...下载中(这里需要全局的科学上网) ?...使用-F指令可以把应用打包成一个独立的exe文件,否则是一个带各种dll和依赖文件的文件夹; -p指令 这个指令后面可以增加pyinstaller搜索模块的路径。因为应用打包涉及的模块很多。

    3.4K42

    python日常技巧(2)将pdf文件中的表格转化成csv文件

    前文介绍 从 PDF 表格中提取表格数据时比较困难的。不久前,一位开发者提供了一个名为 Camelot 的工具,满足大家从 PDF 文件中提取表格数据。...(1)安装 使用conda 安装Camelot的最简单方法是使用[conda](https://conda.io/docs/)进行安装,这是[Anaconda]的软件包管理器和环境管理系统。...conda install -c conda-forge camelot-py Camelot 支持 Python 2.7, 3.5, 3.6 and 3.7 包含 (Linux, macOS and...pywork\\shuiyin') # In[*] >>> import camelot >>> tables = camelot.read_pdf('foo.pdf') #类似于Pandas打开CSV文件的形式...html, sqlite,可指定输出格式 >>> tables[0].to_csv('foo.csv') # to_json, to_excel, to_html, to_sqlite, 导出数据为文件

    3.3K20

    shell脚本中打印所有匹配某些关键字符的行或前后各N行

    在日常运维中,经常需要监控某个进程,并打印某个进程的监控结果,通常需要打印匹配某个结果的行以及其前后各N行。...2)打印/opt/test中所有匹配"main is failed"的行及其前1行 [root@mq-master02 ~]# cat /opt/test |grep "main is failed"...192.168.10.17 5)把/opt/test中所有匹配"main is failed"的行及其前1行的结果打印到/root/result.log中,并加上时间 [root@mq-master02...\n">> /mnt/main_check_result.log fi main检查的结果文件内容 [root@kevin ~]# cat /mnt/main_check_result.log 2018...以上的脚本:不管main进程状态检查结果是否正常,都打印一个结果到/mnt/main_check_result.log文件中, 其实检查结果正常的时候,可以不必打印结果(即echo "****" > /

    3.4K10

    使用uniq命令去除文件中的重复行

    uniq命令全称是“unique”,中文释义是“独特的,唯一的”。该命令的作用是用来去除文本文件中连续的重复行,中间不能夹杂其他文本行。去除了重复的,保留的都是唯一的,也就是独特的,唯一的了。...我们应当注意的是,它和sort的区别,sort只要有重复行,它就去除,而uniq重复行必须要连续,也可以用它忽略文件中的重复行。...语法格式:uniq [参数] [文件] 常用参数: -c 打印每行在文本中重复出现的次数 -d 只显示有重复的纪录,每个重复纪录只出现一次 -u 只显示没有重复的纪录 参考实例 删除连续文件中连续的重复行...95 Linux 85 Linux 85 [root@linuxcool ~]# uniq testfile test 30 Hello 95 Linux 85 打印每行在文件中出现重复的次数...,且每个纪录只出现一次: [root@linuxcool ~]# uniq -d testfile test 30 Hello 95 Linux 85 只显示没有重复的纪录: [root

    3.2K00

    通过Python脚本将DMP文件写入AWS RDS Oracle中

    由于RDS(Oracle)不直接支持SSH,FTP(基于安全因素吧).所以原有系统expdp或exp出来的dmp文件,不能直接导入到RDS中。...查找各种文档发现,可以通过Oracle自身的UTL_FILE包来写dmp文件到RDS的文件夹里,读取EC2里的本地文件部分通过Python脚本实现,这样变相实现了,从EC2本地上传到RDS的功能。...UTL_FILE_CREATE_FILE语句也可以转换为RDS中的一个Function函数: create or replace function gen_dmp(i_name IN VARCHAR2,...',i_name,'ab'); utl_file.put_raw(v_file,i_buffer); utl_file.fclose(v_file); return 'OK'; end; end; 在Python...中调用此函数,这样chunk就可以设置到32767最大值了. def cpy_to_rds_func():     file_name = 'tes4.dmp'     src_name = 'c:/testdata

    2.4K10

    将文件夹中的文件信息统计写入到csv中

    今天在整理一些资料,将图片的名字信息保存到表格中,由于数据有些多所以就写了一个小程序用来自动将相应的文件夹下的文件名字信息全部写入到csv文件中,一秒钟搞定文件信息的保存,省时省力!...下面是源代码,和大家一起共享探讨: import os import csv #要读取的文件的根目录 root_path=r'C:\Users\zjk\Desktop\XXX' # 获取当前目录下的所有目录信息并放到列表中...for dir in dirs: path_lists.append(os.path.join(root_path, dir)) return path_lists #将所有目录下的文件信息放到列表中...def get_Write_file_infos(path_lists): # 文件信息列表 file_infos_list=[] for path in path_lists..."]=filename1 #追加字典到列表中 file_infos_list.append(file_infos) return

    13.2K20
    领券