24小时热门版块排行榜    

查看: 1136  |  回复: 5

alvin510

银虫 (小有名气)

[求助] 求txt中数据重新排序的fortran代码

我用MS计算了一个晶体的能带结构,其结果保存在了unitbands.txt文件中。不幸的是,其中的结果没有按自然顺序排列,即原文件是按k-point =1,k-point=7,k-point=13,k-point=19,k-point=25,kpoint=31,k-point=2,k-point=8,k-point=14.....这种顺序排列的。现在,我想要它按k-point=1,k-point=2,k-point=3,k-point=4......这种顺序排列在txt中。求帮我写一段这样的fortran代码,万分感谢。为方便操作,我把原件上传了上来。
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : unit_bands.txt
  • 2013-07-25 17:42:52, 38.96 K

» 猜你喜欢

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

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

jerkwin

专家顾问 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
排什么序?把数据读到相应的数组里,再按数组顺序输出就是了。
2楼2013-07-25 20:45:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

alvin510

银虫 (小有名气)

引用回帖:
2楼: Originally posted by jerkwin at 2013-07-25 20:45:07
排什么序?把数据读到相应的数组里,再按数组顺序输出就是了。

问题在于我不知道怎么把数据存到相应的数组里。我尝试了很多种循环都不行。如能告知怎么做,我定重金相谢。
3楼2013-07-26 17:26:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

alvin510

银虫 (小有名气)

引用回帖:
2楼: Originally posted by jerkwin at 2013-07-25 20:45:07
排什么序?把数据读到相应的数组里,再按数组顺序输出就是了。

我把数据读入数组时,用的代码是
do nk = 1, nkpts
        read(fileid,"(A80)" dummy
        locat_str = index(dummy,'K-point')
        read(dummy(locat_str+7,*) ndum, kpoints(1,nk), kpoints(2,nk), kpoints(3,nk), weight(nk)
        do ns = 1, nspins
                read(fileid,*) dummy
                do nb = 1, num_bands
            read(fileid,"(3XF11.8)" eigenvalues(nb, nk, ns)
        end do
    enddo
enddo
close(fileid)
其中,nk就代表了k-point序列. 当nk=1时能和txt中的k-pont 1对应。但当nk=2时,读入的是k-point 7的数据,而存进数组的序列为nk=2.后面的也跟着对应不了。求帮助我解决这个难题。万分感谢。
4楼2013-07-26 17:37:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jerkwin

专家顾问 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
alvin510: 金币+10, ★★★★★最佳答案 2013-07-27 09:22:48
这里
read(dummy(locat_str+7,*) ndum, kpoints(1,nk), kpoints(2,nk), kpoints(3,nk), weight(nk)
应该改成
read(dummy(locat_str+7,*) ndum, kpoints(1,ndum), kpoints(2,ndum), kpoints(3,ndum), weight(ndum)
其他类似的地方也要改

有时间弄这些,花两天时间学学bash脚本,早就弄好了。
5楼2013-07-26 21:16:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

rsb_long

至尊木虫 (著名写手)

使用数组就可以解决,任何一本教材中都有标准的解决方案
6楼2013-07-28 08:54:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 alvin510 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 311求调剂 +8 冬十三 2026-03-15 8/400 2026-03-17 16:59 by ruiyingmiao
[考研] 303求调剂 +3 睿08 2026-03-17 3/150 2026-03-17 15:24 by 哦哦123
[考研] 275求调剂 +4 太阳花天天开心 2026-03-16 4/200 2026-03-17 10:53 by 功夫疯狂
[考研] 材料与化工304求B区调剂 +7 邱gl 2026-03-11 8/400 2026-03-17 09:36 by 努力学习赚彩礼
[考研] 278求调剂 +3 Yy7400 2026-03-13 3/150 2026-03-17 08:24 by laoshidan
[考研] 机械专硕325,寻找调剂院校 +3 y9999 2026-03-15 5/250 2026-03-16 19:58 by y9999
[考研] 0854控制工程 359求调剂 可跨专业 +3 626776879 2026-03-14 9/450 2026-03-16 17:42 by 626776879
[基金申请] 今年的国基金是打分制吗? 50+3 zhanghaozhu 2026-03-14 3/150 2026-03-16 17:07 by 北京莱茵润色
[考研] 0703化学调剂 +6 妮妮ninicgb 2026-03-15 9/450 2026-03-16 16:40 by houyaoxu
[考研] 285求调剂 +6 ytter 2026-03-12 6/300 2026-03-16 15:05 by njzyff
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 0856专硕279求调剂 +5 加油加油!? 2026-03-15 5/250 2026-03-15 11:58 by 2020015
[考研] 中科大材料专硕319求调剂 +3 孟鑫材料 2026-03-13 3/150 2026-03-14 18:10 by houyaoxu
[考研] 290求调剂 +9 ADT 2026-03-11 9/450 2026-03-13 21:55 by JourneyLucky
[考研] 一志愿西南交大,材料专硕317求调剂 +5 lx8568 2026-03-11 5/250 2026-03-13 21:43 by peike
[考研] 304求调剂 +7 7712b 2026-03-13 7/350 2026-03-13 21:42 by peike
[考研] 求调剂 +3 程雨杭 2026-03-12 3/150 2026-03-13 15:06 by JourneyLucky
[考研] 0817化学工程与技术考研312分调剂 +3 T123 tt 2026-03-12 3/150 2026-03-13 10:49 by houyaoxu
[考博] 2026年博士申请 +3 QwQwQW10 2026-03-11 3/150 2026-03-12 17:58 by gxch43
[考研] 290求调剂 +3 柯淮然 2026-03-10 8/400 2026-03-11 13:48 by 柯淮然
信息提示
请填处理意见