加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

perl学习笔记(5)

发布时间:2020-12-16 00:27:07 所属栏目:大数据 来源:网络整理
导读:哈希列表和普通列表的差别是:哈希列表的索引是有业务含义的,普通列表的索引是数字。根据索引从哈希列表中获取信息的速度很快。 哈希列表变量用%开头。 哈希列表键值不能重复,如果重复,后面的值会覆盖前面的值。这一特性善加利用可用于统计单词出现的频率

哈希列表和普通列表的差别是:哈希列表的索引是有业务含义的,普通列表的索引是数字。根据索引从哈希列表中获取信息的速度很快。

哈希列表变量用%开头。

哈希列表键值不能重复,如果重复,后面的值会覆盖前面的值。这一特性善加利用可用于统计单词出现的频率。

测试哈希列表中是否存在某元素,不能用if($Hash{keyval}){...},应该用if(exists $Hash{keyval}){...}。

将哈希列表的元素取值设置为undef不能删除这个元素,删除元素应该用delete $Hash{keyval}。清空哈西列表用$Hash=()。

没太搞明白$_的含义。手头这个教材有点老,教学案例中用perl承担数据库的功能有些勉为其难了,但是在没有数据库的情况下perl还是能解决一些问题的。

练习(f51.pl):

 
 
  1. #!/usr/bin/perl?-w ?
  2. %food=(?apple=>'fruit',?
  3. ????????pear?=>'fruit',?
  4. ???????carrot=>'vegetable'); ?
  5. #print?qq($food{'pear'}n); ?
  6. $food{banana}='fruit'; ?
  7. @food=%food; ?
  8. print(qq(food?list?is:n?@{food}.n)); ?
  9. foreach?my?$eat?(keys?%food){ ?
  10. ????????print?qq(food[$eat]=$food{$eat}n); ?
  11. } ?
  12. print(qq(after?reverse?...?n)); ?
  13. %food=reverse(%food); ?
  14. @food=%food; ?
  15. print(qq(food?list?is:n?@{food}.n)); ?
  16. foreach?my?$eat?(keys?%food){ ?
  17. ????????print?qq(food[$eat]=$food{$eat}n); ?
  18. }?

$ perl f51.pl
food list is:
?banana fruit carrot vegetable apple fruit pear fruit.
food[banana]=fruit
food[carrot]=vegetable
food[apple]=fruit
food[pear]=fruit
after reverse ...
food list is:?
?fruit banana vegetable carrot.
food[fruit]=banana
food[vegetable]=carrot
从这个练习中可以看出,reverse(%food)后,因为fruit重复的原因,后面的元素覆盖了前面的元素,哈希列表的元素个数变少了。简而言之,哈希列表的reverse通常是不可逆的,要可逆必须一一对应,且两边都不能有重复。

这次就写到这里吧。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读