| 查看: 2006 | 回复: 23 | |||
| 当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖 | |||
[交流]
【求助】如何实现数字紧贴字母输入
|
|||
|
H 1 H 2 H 3 H 4 H 5 H 6 H 7 H 8 H 9 H 10 H 11 H 12 请教前辈,如何让后面的数字紧贴着字母输入呢后面还有几百行 |
» 猜你喜欢
298求调剂
已经有10人回复
284求调剂
已经有3人回复
面上模板改不了页边距吧?
已经有5人回复
276求调剂
已经有4人回复
085600材料工程一志愿中科大总分312求调剂
已经有9人回复
博士推荐
已经有6人回复
0856材料求调剂
已经有11人回复
311求调剂
已经有7人回复
材料学调剂
已经有4人回复
高分子化学与物理调剂
已经有5人回复
» 本主题相关价值贴推荐,对您同样有帮助:
【求助】光栅重构DLP(Discrete Layer Peeling)模型
已经有2人回复
【资源】催化剂制备中浸渍(等体积浸渍)不断改进
已经有151人回复
【求助】帮忙看一段程序
已经有9人回复
【讨论】80后”创业者何以前仆后继
已经有0人回复
【分享】巨牛总结:搞有机必须学会的合成检索方法
已经有169人回复
» 抢金币啦!回帖就可以得到:
长春工业大学课题组招收硕士调剂生(化工、化学、材料、环境、制药、生物等方向)
+1/571
高级研发工程师/研发工程师 – 锂离子电池正极材料回收与制备-香港纳米及先进材料研发
+1/283
澳大利亚昆士兰大学化工学院吕妙强课题组招收项目支持的全奖博士生2名
+1/81
广工-董华锋教授团队招收博士生(1学博-0-1专博)
+1/74
招收桥梁工程方向博士研究生!
+3/71
【最后机会】深圳大学2026级土木工程博士急招
+5/70
青岛科技大学2026年高分子材料方向科研助理招聘
+1/32
中国科学院国家级人才团队博士后招聘启示
+1/11
中科院深圳先进技术研究院成会明院士/唐永炳杰青团队拟招聘博士后若干名。
+1/8
哈尔滨工业大学张洪教授招收2026年海洋科学(环境、化学、生物方向)硕士研究生
+1/7
湖南理工学院有机合成化学方向招收化学化工类调剂学生
+1/5
【全奖博士招生】美国科罗拉多大学科罗拉多斯普林斯分校----固体与结构力学
+1/4
深圳大学何传新课题组诚聘“百人计划”(副)教授、助理教授
+1/4
武汉纺织大学2026年招收硕士研究生【高性能、功能纺织复合材料方向】
+1/4
国家优青李洪森教授招收2026年申请考核制博士2名
+1/4
26届计算机、电子信息类、电科、控制、通信考研T j信息pp骏:74+08+76+6+20
+1/4
26届计算机、电子信息类、电科、控制、通信考研T j信息pp骏:74+08+76+6+20》
+1/4
蛋白结构质谱实验室202609入学博士生(1名,202603月底报名)
+1/3
智能电网与AI4Energy|港科大(广州)博士招生
+1/3
新加坡南洋理工大学- 光电/ 智能传感/ 脑机接口方向 博士后
+1/1
★ ★
jjdg(金币+2): 感谢参与 2011-06-17 22:09:03
jjdg(金币+2): 感谢参与 2011-06-17 22:09:03
|
好的,找来看一看 fortran对于格式的要求很严格,刚开始读取数据的时候出现的是 At line 10 of file tiH.f90 (unit = 17, file = 'wa_xyz.dat') Fortran runtime error: End of file 这个错误修改之后,对于读取和写入数据采取不同的格式之后,看出了问题所在,下面是 [code:] program main implicit none integer i,j character B real A dimension B(768),A(768,3) open(17,file='wa_xyz',status='old') do i=1,768 read (17,*) B(i),A(i,1),A(i,2),A(i,3) end do close(17) open(18,file='nem_wa_xyz',status='unknown') do i=1,768 if(mod(i,3)/=0)then write(18,*)(B(i),A(i,j),j=1,3) end if end do close(18) stop end program [code:] 读取这样一段数据: O 3.668000 10.082000 15.904000 H 3.224000 10.451000 15.101000 H 3.092000 10.379000 16.627001 O 5.186000 16.695999 12.072000 H 6.083000 16.979000 11.816000 H 5.337000 15.832000 12.490000 O 3.786000 16.318001 1.310000 H 3.781000 15.388000 1.196000 H 4.528000 16.580000 0.781000 O 6.205000 6.991000 18.441999 H 6.782000 7.347000 19.152000 H 5.309000 7.062000 18.799999 O 16.125999 14.701000 4.577000 H 16.070000 14.272000 3.726000 ……………………………………………………………………………… 得到的如下 O 3.6680000 O 10.082000 O 15.904000 H 3.2240000 H 10.451000 H 15.101000 O 5.1859999 O 16.695999 O 12.072000 H 6.0830002 H 16.979000 H 11.816000 O 3.7860000 O 16.318001 O 1.3099999 H 3.7809999 H 15.388000 H 1.1960000 O 6.2049999 O 6.9910002 O 18.441999 H 6.7820001 H 7.3470001 H 19.152000 O 16.125999 O 14.701000 O 4.5770001 H 16.070000 H 14.272000 H 3.7260001 O 2.7500000 O 8.8439999 O 9.6289997 H 2.1099999 H 8.2900000 H 9.9980001 O 10.674000 O 8.9090004 O 4.9860001 H 10.998000 H 8.8710003 H 5.9320002 O 2.00000009E-03 O 5.6669998 O 14.591000 H 0.48300001 H 5.9899998 H 13.830000 ……………………………………………………………………………… 这就可以明显的看出问题是出在哪里了,本来读取数据的时候采用的是和写入一样的方式(B(i),A(i,j),j=1,3),一直出现上面的错误,记录一下,以备日后学习汲取教训 [ Last edited by xk6891 on 2011-3-20 at 13:20 ] 进一步修改成这样就顺多了,首先要能读,然后才是写入数据 code: program main implicit none integer i,j character B real A dimension B(768),A(768,3) open(17,file='wa_xyz',status='old') do i=1,768 read(17,*)B(i),A(i,1),A(i,2),A(i,3) end do close(17) open(18,file='nem_wa_xyz',status='unknown') do i=1,768 if(mod(i,3)/=0)then write(18,"(A3,3(F16.6))" B(i),A(i,1),A(i,2),A(i,3)end if end do close(18) stop end program code: 得到的结果 O 3.668000 10.082000 15.904000 H 3.224000 10.451000 15.101000 O 5.186000 16.695999 12.072000 H 6.083000 16.979000 11.816000 O 3.786000 16.318001 1.310000 H 3.781000 15.388000 1.196000 O 6.205000 6.991000 18.441999 H 6.782000 7.347000 19.152000 O 16.125999 14.701000 4.577000 H 16.070000 14.272000 3.726000 O 2.750000 8.844000 9.629000 [ Last edited by xk6891 on 2011-3-20 at 13:25 ] |
22楼2011-01-13 23:56:56
★ ★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
xk6891(金币+5):谢谢前辈,问题解决了。用了第二种方法 2011-01-12 10:32:06
余泽成(金币+3):谢谢参与应助! 2011-01-13 19:47:34
小木虫(金币+0.5):给个红包,谢谢回帖交流
xk6891(金币+5):谢谢前辈,问题解决了。用了第二种方法 2011-01-12 10:32:06
余泽成(金币+3):谢谢参与应助! 2011-01-13 19:47:34
|
program align_left_output_1 do i=1,200 L=int(log10(i*1.0))+1 write(*,100) i enddo 100 format('H'I end program program align_left_output_2 character*8 tmpchar do i=1,200 write(tmpchar,'(I8)') i write(*,*) 'H'//adjustl(tmpchar) enddo end program 第一种方法形式简单,容易理解。但变宽度输出依赖于编译器,可移植性不好;而且用到了对数运算,在数据量很大时效率较低。 第二种方法借用了临时字符串做内部文件,效率可能更高一些。 |
2楼2011-01-12 09:17:49
3楼2011-01-12 10:37:14
4楼2011-01-12 13:49:20













回复此楼
B(i),A(i,1),A(i,2),A(i,3)