24小时热门版块排行榜    

查看: 870  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料,纺织,生物(0856、0710),化学招生啦 +3 Eember. 2026-03-17 7/350 2026-03-17 20:20 by 花125533
[考研] 材料专硕326求调剂 +6 墨煜姒莘 2026-03-15 7/350 2026-03-17 17:10 by ruiyingmiao
[考研] 材料与化工专硕调剂 +5 heming3743 2026-03-16 5/250 2026-03-17 14:03 by 勇敢太监王公公
[考研] 材料与化工304求B区调剂 +7 邱gl 2026-03-11 8/400 2026-03-17 09:36 by 努力学习赚彩礼
[考研] 274求调剂 +5 时间点 2026-03-13 5/250 2026-03-17 07:34 by 热情沙漠
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 283求调剂 +10 小楼。 2026-03-12 14/700 2026-03-16 16:08 by 13811244083
[考研] 085600调剂 +5 漾漾123sun 2026-03-12 6/300 2026-03-16 15:58 by 漾漾123sun
[考研] 070303 总分349求调剂 +3 LJY9966 2026-03-15 5/250 2026-03-16 14:24 by xwxstudy
[考研] 277材料科学与工程080500求调剂 +3 自由煎饼果子 2026-03-16 3/150 2026-03-16 14:10 by 运气yunqi
[考研] 机械专硕调剂 +3 笨笨兔子 2026-03-12 3/150 2026-03-15 20:02 by 栗子粥?
[考研] 材料080500调剂求收留 +3 一颗meteor 2026-03-13 3/150 2026-03-14 10:54 by peike
[考研] 学硕285求调剂 +13 Wisjxn 2026-03-12 46/2300 2026-03-14 10:33 by JourneyLucky
[考研] 337一志愿华南理工0805材料求调剂 +7 mysdl 2026-03-11 9/450 2026-03-13 22:43 by JourneyLucky
[考研] 材料工程调剂 +9 咪咪空空 2026-03-12 9/450 2026-03-13 22:05 by 星空星月
[考研] 求材料调剂 +5 隔壁陈先生 2026-03-12 5/250 2026-03-13 22:03 by 星空星月
[考研] 311求调剂 +3 冬十三 2026-03-13 3/150 2026-03-13 20:41 by JourneyLucky
[考研] 求调剂 +5 一定有学上- 2026-03-12 5/250 2026-03-13 18:31 by ms629
[考研] 材料专硕350 求调剂 +4 王金科 2026-03-12 4/200 2026-03-13 16:02 by ruiyingmiao
[考研] 274求调剂 +3 S.H1 2026-03-12 3/150 2026-03-13 15:15 by JourneyLucky
信息提示
请填处理意见