免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 程序设计 Perl Unpack
最近访问板块 发新帖
查看: 2224 | 回复: 6

Unpack [复制链接]

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
发表于 2011-12-28 06:56 |显示全部楼层
本帖最后由 yinyuemi 于 2011-12-28 06:58 编辑

工作中遇到个问题,劳烦大家指点下!

在Ruby中使用String Class中的str.unpack('G*')解析字符串,返回float type值:
  1. Float        |         |
  2. Directive    | Returns | Meaning
  3. G         | Float   | double-precision, network (big-endian) byte order
复制代码
如何用perl实现这样的功能呢?
注:如果字符串格式是32-bit unsigned, network byte order,我的办法是unpack("f",pack("I",unpack("N*",$str))),
但现在的情况是,字符串格式为64-bit unsigned, network byte order,不知怎么处理?
查看手册,貌似使用修饰符 '<' '>' 有可能实现,不过没成功,请各位大大指点下,多谢!

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
发表于 2011-12-28 10:13 |显示全部楼层
什么和什么啊,64位需要用 64位的 Perl,不行你手工转下顺序就是了

unpack("f",pack("I",unpack("N*",$str)))
是干什么的?

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
发表于 2011-12-28 13:28 |显示全部楼层
本帖最后由 yinyuemi 于 2011-12-28 13:30 编辑

回复 2# zhlong8

恩,我是用64为perl测试的,斑竹你提到的手动转顺序是什么?能详细说下么?

刚找到解决办法是 unpack ("d>",$str),可以解决double precision的问题,不过依然没有解决network byte的问题
   

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
发表于 2011-12-28 13:33 |显示全部楼层
浮点数也有大小端问题?

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
发表于 2011-12-28 13:48 |显示全部楼层
回复 4# zhlong8


    恩,$str是 C程序生成的,base64 encode之前的数据type定义是double。(我的专业不是计算机,可能说的不准确)

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
发表于 2011-12-28 14:02 |显示全部楼层
回复 5# yinyuemi


    不知道你到底还干什么,得到数据的字符串表示然后对照着 pack 函数文档中的那个表用 unpack 不就行了,order 用 >< 设置下就是了。

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
发表于 2011-12-28 15:04 |显示全部楼层
回复 6# zhlong8

恩,多谢啦~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会 限时8.5折

【架构革新 高效可控】2020年8月17日~19日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP