24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 875  |  回复: 3

043114076

木虫 (正式写手)

[交流] 【原创】DL_POLY STATIS 数据提取的shell脚本实现 已有2人参与

STATIS文件的结构是这样的:

RECORD
ENERGY UNITS=kjoule/mol
      100  1.000000E-01        57
  -4.511110E+05   4.099103E+02 -4.527781E+05 -2.340504E+03 -4.518018E+05
  2.502369E+02  9.021103E+02  2.118284E+02  0.000000E+00 -4.542574E+05
  0.000000E+00  1.259219E+04  1.509093E+03  9.414544E+03 -2.528589E+02
  0.000000E+00  1.921407E+03  0.000000E+00  1.369171E+04  0.000000E+00
  0.000000E+00  0.000000E+00  9.000000E+01  9.000000E+01  9.000000E+01
  0.000000E+00 -3.722719E+00  7.904863E-02  8.569857E-02  1.611124E-01
  1.765559E-01  1.112503E-01  2.658214E-01  3.051339E-01  8.195875E-01
  4.890081E-01  1.705623E-01  1.978958E-01  0.000000E+00  0.000000E+00
  0.000000E+00  0.000000E+00  0.000000E+00  0.000000E+00  0.000000E+00
  0.000000E+00  0.000000E+00  0.000000E+00 -4.207968E+00 -1.568472E+00
-2.366729E-02 -1.568472E+00 -2.741807E+00 -1.594941E+00 -2.366729E-02
-1.594941E+00 -4.218381E+00
       200  2.000000E-01        57
-4.511112E+05   4.099364E+02 -4.528451E+05 -2.336209E+03 -4.518143E+05
  2.786064E+02  8.259597E+02  2.008752E+02  0.000000E+00 -4.557601E+05
  0.000000E+00  1.689977E+04  1.537109E+03  9.424109E+03  3.734186E+03
  0.000000E+00  2.204361E+03  0.000000E+00  1.369171E+04  0.000000E+00
  0.000000E+00  0.000000E+00  9.000000E+01  9.000000E+01  9.000000E+01
  0.000000E+00 -5.441284E+00  2.458810E-01  2.129879E-01  2.726666E-01
  3.423946E-01  2.721395E-01  5.091896E-01  4.866978E-01  1.504921E+00
  1.095589E+00  5.472309E-01  7.263942E-01  0.000000E+00  0.000000E+00
  0.000000E+00  0.000000E+00  0.000000E+00  0.000000E+00  0.000000E+00
  0.000000E+00  0.000000E+00  0.000000E+00 -6.088646E+00 -3.515484E-01
-8.385491E-01 -3.515484E-01 -5.695090E+00  1.820125E-01 -8.385491E-01
  1.820125E-01 -4.540118E+00

……

要提取红色部分的数据,使用fortran或其他语言很容易实现,但是为了下一步操作我尝试使用shell脚本实现:

#!/bin/sh
#read data from STATIS then plot
   line_num=$(grep -n '^ \{4,\}' STATIS | cut -d ":" -f 1 ) #得到绿色部分的行数
   for i in $line_num
   do
     sed -n "$(($i+1))p" STATIS | awk '{print $1}' >> tmp #提取i+1行中第一个数据,保存到tmp文件
   done

实现的过程是首先得到绿色部分的行数,然后提取i+1行的第一个数据。
由于初学shell脚本,发现运行效率很低,分享的同时也希望大家能帮助修改一下。

[ Last edited by 043114076 on 2011-1-5 at 20:52 ]
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

043114076

木虫 (正式写手)

运行效率低的原因,可能是由于对文件操作次数太多。第一次查找,第二-N次是循环提取数据。怎么才能不需要那个循环呢?
2楼2011-01-05 20:59:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zyj8119

木虫 (著名写手)

引用回帖:
Originally posted by 043114076 at 2011-01-05 20:46:06:
STATIS文件的结构是这样的:

RECORD
ENERGY UNITS=kjoule/mol
      100  1.000000E-01        57
  -4.511110E+05   4.099103E+02 -4.527781E+05 -2.340504E+ ...

这个是AWK语言?
好好学习,天天向上。
3楼2011-01-05 21:32:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

043114076

木虫 (正式写手)

★ ★ ★ ★ ★
ghcacj(金币+5):谢谢 2011-01-06 09:13:30
引用回帖:
Originally posted by zyj8119 at 2011-01-05 21:32:15:

这个是AWK语言?

是shell脚本语言

通过在网上搜索终于找到更为简单的解决办法,只需要一句命令:
方法一:
sed -n '/^ \{4,\}/{n;p;}' STATIS | awk '{print $1}'
方法二:
awk '/^    /{getline;print $1}' STATIS

取包含某一字符行的以下所有x行的数据
awk '/^    / {for(i=0;i
取包含某一字符行的以下第4行的数据
sed -n '/^ \{4,\}/{n;n;n;n;p;}' STATIS | awk '{print $1}'  #这个是我自己扩展的,取第几行就写几个n

参考:http://www.chinaunix.net/jh/24/15796.html

[ Last edited by 043114076 on 2011-1-5 at 22:52 ]
4楼2011-01-05 22:39:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 043114076 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +3 努力奋斗112 2026-04-06 3/150 2026-04-07 08:35 by jp9609
[考研] (调剂)一志愿报考哈尔滨工业大学0857资源与环境专业378分考生 +7 狠狠加油 2026-04-05 8/400 2026-04-06 16:52 by momo皓
[考研] 求调剂到材料 +5 程9915 2026-04-06 5/250 2026-04-06 15:21 by yulian1987
[考研] 一志愿武汉理工大学080200机械工程308分,求调剂 +4 终不似从前 2026-04-05 4/200 2026-04-06 11:46 by 考研学校招点人
[考研] 化学调剂 +17 艾志恒 2026-04-03 18/900 2026-04-06 07:10 by jj987
[考研] 313求调剂 +5 海日海日 2026-04-04 5/250 2026-04-05 15:52 by jndximd
[考研] 调剂 +3 好好读书。 2026-04-02 3/150 2026-04-05 13:02 by arrow8852
[考研] 一志愿西北农林畜牧专硕336分求调剂 +3 5ourr 2026-04-03 3/150 2026-04-05 10:40 by JOKER0401
[考研] 材料化工306分找合适调剂 +14 沧海轻舟e 2026-04-04 14/700 2026-04-05 09:53 by 朱云虎202
[考研] 本科211 分数293请求调剂 +4 莲菜就是藕吧 2026-04-01 4/200 2026-04-04 22:32 by hemengdong
[考研] 调剂 +4 是可乐不是可乐 2026-04-04 4/200 2026-04-04 19:41 by 唐沐儿
[考研] 材料调剂 +11 吴棂颖! 2026-04-03 11/550 2026-04-04 09:56 by 小小树2024
[考研] 调剂 +5 asdasdassda 2026-04-03 6/300 2026-04-03 20:27 by 岸上的一条鱼
[考研] 085501一志愿天工大,机械专硕求调剂,跨材料 +3 33上 2026-04-03 3/150 2026-04-03 14:08 by 1753564080
[考研] 0705理学294求调剂 +3 成果成果cg5 2026-04-03 3/150 2026-04-03 14:04 by simons1972
[考研] 调剂 +7 祉岷. 2026-04-02 7/350 2026-04-03 09:11 by 花呗还欠600
[考研] 一志愿北京科技大学材料学硕328分求调剂 +6 1段时间 2026-03-31 7/350 2026-04-02 13:57 by 3041
[考研] 298求B区调剂 +4 zzz,,r 2026-04-02 5/250 2026-04-02 12:17 by 土木硕士招生
[考研] 372求调剂 +3 jj涌77 2026-04-02 3/150 2026-04-02 09:57 by olim
[考研] 复试调剂 +7 双马尾痞老板2 2026-03-31 7/350 2026-03-31 19:49 by Dyhoer
信息提示
请填处理意见