爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索

如何一次读取一个月的OMI Grid HDF 文件,并求均值

[复制链接]

新浪微博达人勋

发表于 2017-3-30 21:24:53 | 显示全部楼层
一股夏天的风 发表于 2017-3-30 19:46
谢谢老师指点,查看学习了Python的语言,修改了语句,再次运行时错误如下
Traceback (most recent call  ...

addfiles函数要求文件中必须有时间维,也许你的数据文件缺少时间维。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2017-3-30 22:51:13 | 显示全部楼层
本帖最后由 MeteoInfo 于 2017-3-31 22:29 编辑
一股夏天的风 发表于 2017-3-30 19:46
谢谢老师指点,查看学习了Python的语言,修改了语句,再次运行时错误如下
Traceback (most recent call  ...

可以不用addfiles,利用循环来做平均:

  1. datadir = 'F:/OMI'
  2. st = datetime.datetime(2017,1,1)
  3. et = datetime.datetime(2017,1,2)
  4. vname = 'ColumnAmountO3'
  5. ave = None
  6. n = 0
  7. while st <= et:
  8.     fn = os.path.join(datadir, ' OMI-Aura_L3-OMTO3e_' + st.strftime('%Y%m%d') + '.he5')
  9.     f = addfile(fn)
  10.     data = f[vname]['32:55', '95:128']
  11.     if ave is None:
  12.         ave = data
  13.     else:
  14.         ave = ave + data
  15.     n += 1
  16.     st = st + datetime.timedelta(days=1)

  17. data = ave / n

  18. #Plot
  19. axesm()
  20. lhuabei=shaperead('D:/BaiduNetdiskDownload/MeteoInfo/MeteoInfo_Java_1.4.2_Files/MeteoInfo/map/huabei.shp ')
  21. geoshow(lhuabei, edgecolor='k')
  22. layer = imshowm(data)
  23. colorbar(layer)

密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2017-3-31 09:39:46 | 显示全部楼层
MeteoInfo 发表于 2017-3-30 22:51
可以不用addfiles,利用循环来做平均:

王老师,非常感谢您的帮助,我试了您给的程序,运行错误如下;
> run script...
  File "<iostream>", line 8
    &Acirc;&nbsp; &Acirc;&nbsp; fn = os.path.join(datadir, 'OMI-Aura_L3-OMTO3e_' + st.strftime('%Y%m%d')+ '.he5')
    ^
SyntaxError: no viable alternative at character '&nbsp;'
我想大概是符号格式的问题,重写引号还是同样问题,是不是he5数据本身的问题?百思不得其解,请您给看看
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2017-3-31 09:43:21 | 显示全部楼层
一股夏天的风 发表于 2017-3-31 09:39
王老师,非常感谢您的帮助,我试了您给的程序,运行错误如下;
> run script...
  File "", line 8

你不要把格式符号也复制成代码了呀!
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2017-3-31 16:37:52 | 显示全部楼层
MeteoInfo 发表于 2017-3-31 09:43
你不要把格式符号也复制成代码了呀!

已经运行成功了,非常感谢您的耐心指导,自己的编程能力需要提高
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2017-3-31 21:08:09 | 显示全部楼层
MeteoInfo 发表于 2017-3-31 09:43
你不要把格式符号也复制成代码了呀!

王老师,如果我想统计数值中的最大和最小值,均值,应该用什么函数?在论坛里好像没有找到相关帖子,谢谢您
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2017-3-31 22:29:15 | 显示全部楼层
一股夏天的风 发表于 2017-3-31 21:08
王老师,如果我想统计数值中的最大和最小值,均值,应该用什么函数?在论坛里好像没有找到相关帖子,谢谢 ...

获取的数组有 max() 和 min() 函数来获取数组的最大最小值。比如:

max = data.max()
min = data.min()
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2017-3-31 22:31:16 | 显示全部楼层
一股夏天的风 发表于 2017-3-31 21:08
王老师,如果我想统计数值中的最大和最小值,均值,应该用什么函数?在论坛里好像没有找到相关帖子,谢谢 ...

12楼之前的脚本有点问题:

18行代码: data = data / n    改为:    data = ave / n
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2017-4-12 21:56:28 | 显示全部楼层
MeteoInfo 发表于 2017-3-31 22:31
12楼之前的脚本有点问题:

18行代码: data = data / n    改为:    data = ave / n

王老师,如何输出某一确定经纬度的数值?应该用什么语句?
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2017-4-13 08:31:37 | 显示全部楼层
一股夏天的风 发表于 2017-4-12 21:56
王老师,如何输出某一确定经纬度的数值?应该用什么语句?

类似这样,获取经度100,纬度40的数据:
v =data['40', '100']
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表