24小时热门版块排行榜    

查看: 1137  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085601专硕,总分342求调剂,地区不限 +4 share_joy 2026-03-16 4/200 2026-03-17 21:32 by hmn_wj
[考研] 341求调剂 +5 捣蛋猪猪 2026-03-11 7/350 2026-03-17 19:09 by 捣蛋猪猪
[考研] 0703化学336分求调剂 +4 zbzihdhd 2026-03-15 5/250 2026-03-17 17:33 by ruiyingmiao
[考研] 化学工程321分求调剂 +11 大米饭! 2026-03-15 14/700 2026-03-17 17:11 by ruiyingmiao
[考研] 085600材料与化工 +4 安全上岸! 2026-03-16 4/200 2026-03-17 14:02 by 勇敢太监王公公
[考研] 278求调剂 +3 Yy7400 2026-03-13 3/150 2026-03-17 08:24 by laoshidan
[考研] [导师推荐]西南科技大学国防/材料导师推荐 +3 尖角小荷 2026-03-16 6/300 2026-03-16 23:21 by 尖角小荷
[考研] 0703化学调剂,求各位老师收留 +8 秋有木北 2026-03-14 8/400 2026-03-16 15:21 by 哦哦123
[教师之家] 焦虑 +7 水冰月月野兔 2026-03-13 9/450 2026-03-16 10:00 by Quakerbird
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 289求调剂 +4 这么名字咋样 2026-03-14 6/300 2026-03-14 18:58 by userper
[基金申请] 现在如何回避去年的某一个专家,不知道名字 +3 zk200107 2026-03-12 6/300 2026-03-14 17:13 by zk200107
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
[考研] 求调剂(材料与化工327) +4 爱吃香菜啦 2026-03-11 4/200 2026-03-13 22:11 by JourneyLucky
[考研] 材料工程调剂 +9 咪咪空空 2026-03-12 9/450 2026-03-13 22:05 by 星空星月
[考研] 281求调剂 +9 Koxui 2026-03-12 11/550 2026-03-13 20:50 by Koxui
[考研] 311求调剂 +3 冬十三 2026-03-13 3/150 2026-03-13 20:41 by JourneyLucky
[考研] 一志愿山大07化学 332分 四六级已过 本科山东双非 求调剂! +3 不想理你 2026-03-12 3/150 2026-03-13 14:18 by JourneyLucky
[考研] 277求调剂 +4 anchor17 2026-03-12 4/200 2026-03-13 11:15 by 白夜悠长
[考研] 270求调剂 085600材料与化工专硕 +3 YXCT 2026-03-11 3/150 2026-03-13 10:13 by houyaoxu
信息提示
请填处理意见