计算化学公社

 找回密码 Forget password
 注册 Register
Views: 1619|回复 Reply: 3
打印 Print 上一主题 Last thread 下一主题 Next thread

[综合讨论] [脚本] 批量自动提取cp2k能量计算结果中的Total Energy

[复制链接 Copy URL]

44

帖子

0

威望

310

eV
积分
354

Level 3 能力者

本帖最后由 stishovite 于 2024-5-20 08:07 编辑


手动提取能量计算结果是个大工程,于是编了下面这个自动提取最终能量值的脚本(见附件):

  1. @echo off
  2. setlocal enabledelayedexpansion

  3. set "output_file=TotalEnergy.csv"
  4. echo File Name,Total Energy > "%output_file%"

  5. for %%F in (*.out) do (
  6.     set "final_energy="
  7.     for /f "usebackq delims=" %%L in ("%%F") do (
  8.         set "line=%%L"
  9.         if not "!line:Total energy=!"=="!line!" set "final_energy=!line!"
  10.     )
  11.     if defined final_energy (
  12.         for /f "tokens=3" %%E in ("!final_energy!") do (
  13.             echo %%F,%%E >> "%output_file%"
  14.         )
  15.     )
  16. )

  17. echo Done! Total Energy data saved to "%output_file%".
复制代码


将TotalEnergy.bat放在cp2k能量计算结果的文件夹中,双击运行,即可自动提取*.out文件中Total Energy的最终值,并在当前目录下生成TotalEnergy.csv文件,可直接用Excel打开,很方便。

下图是打开TotalEnergy.csv后的样子。



TotalEnergy.bat (548 Bytes, 下载次数 Times of downloads: 34)

如果大家还有好的意见建议,请留言。


评分 Rate

参与人数
Participants 3
eV +8 收起 理由
Reason
小可几何 + 1 赞!
wangyj + 2 谢谢
sobereva + 5

查看全部评分 View all ratings

4

帖子

0

威望

91

eV
积分
95

Level 2 能力者

2#
发表于 Post on 2026-1-26 16:57:00 | 只看该作者 Only view this author
是不是来一个for循环更方便
for i in {01..20}; do echo -n "image_${i}: "; grep "Total FORCE_EVAL" energy_${i}.out | tail -n 1 | awk '{print $NF}'; done

1238

帖子

6

威望

2533

eV
积分
3891

Level 5 (御坂)

傻傻的木瓜

3#
发表于 Post on 2026-1-26 18:24:22 | 只看该作者 Only view this author
112233112233 发表于 2026-1-26 16:57
是不是来一个for循环更方便
for i in {01..20}; do echo -n "image_${i}: "; grep "Total FORCE_EVAL" ene ...

楼主看起来是打算把CP2K计算结果下载到Windows再用bat脚本提取结果的,而你这个是在Linux里面跑的shell命令,其实都用了for循环的逻辑,循环时文件名怎么用变量确定得看具体情形。

另外,awk 里面 $NF 代表的是一行内的总field数而不是某个field的内容。循环每个文件时不需要 grep | tail | awk 这么多重的 pipe ,对于匹配文本不涉及跨行、只需要文件末尾最后一个结果的情况,grep | tail 的逻辑可以用反向 cat 即 tac 代替:
  1. tac energy_${i}.out | awk '/ENERGY| Total FORCE_EVAL ( QS ) energy/ { print $9; exit }'
复制代码
√546=23.36664289109

44

帖子

0

威望

310

eV
积分
354

Level 3 能力者

4#
 楼主 Author| 发表于 Post on 2026-1-29 15:09:46 | 只看该作者 Only view this author
Uus/pMeC6H4-/キ 发表于 2026-1-26 18:24
楼主看起来是打算把CP2K计算结果下载到Windows再用bat脚本提取结果的,而你这个是在Linux里面跑的shell命 ...

谢谢大神的优化方案

本版积分规则 Credits rule

手机版 Mobile version|北京科音自然科学研究中心 Beijing Kein Research Center for Natural Sciences|京公网安备 11010502035419号|计算化学公社 — 北京科音旗下高水平计算化学交流论坛 ( 京ICP备14038949号-1 )|网站地图

GMT+8, 2026-2-16 16:55 , Processed in 0.265994 second(s), 24 queries , Gzip On.

快速回复 返回顶部 返回列表 Return to list