当前位置: 首页 > news >正文

Python hash编码(go hash编码)

id="中国人"

首先,go语言hash:

import (mmh3 "murmurhash3")
mmh3.Murmurhash3([]byte(id))

对应到Python hash编码,可以直接使用mmh3

import mmh3
mmh3.hash(id,signed=False)

其源码可以表示为

def sum32WithSeed(datas, seed=0):c1_32 = 0xcc9e2d51c2_32 = 0x1b873593h1 = seeddatas_bytes = datas.encode('utf-8')datas_bytes_len = len(datas_bytes)if datas_bytes_len == 0:return 0nblocks = datas_bytes_len // 4for id in range(datas_bytes_len):if id % 4 != 0 or id + 4 > datas_bytes_len:continuek1 = int.from_bytes(datas_bytes[id:id + 4], byteorder='little', signed=False)k1 *= c1_32k1 &= 0xffffffffk1 = (k1 << 15) | (k1 >> 17)k1 *= c2_32k1 &= 0xffffffffh1 ^= k1h1 = (h1 << 13) | (h1 >> 19)h1 = h1 * 4 + h1 + 0xe6546b64h1 &= 0xfffffffftail = datas_bytes[nblocks * 4:]tail_len = len(tail)k1 = 0for id in [3, 2, 1]:if tail_len >= id and id == 3:k1 ^= int.from_bytes(tail[2:3], byteorder='little', signed=False) << 16if tail_len >= id and id == 2:k1 ^= int.from_bytes(tail[1:2], byteorder='little', signed=False) << 8if tail_len >= id and id == 1:k1 ^= int.from_bytes(tail[0:1], byteorder='little', signed=False)k1 *= c1_32k1 &= 0xffffffffk1 = (k1 << 15) | (k1 >> 17)k1 *= c2_32k1 &= 0xffffffffh1 ^= k1h1 &= 0xffffffffh1 ^= datas_bytes_lenh1 ^= h1 >> 16h1 *= 0x85ebca6bh1 &= 0xffffffffh1 ^= h1 >> 13h1 *= 0xc2b2ae35h1 &= 0xffffffffh1 ^= h1 >> 16return h1def sum32(datas):return sum32WithSeed(datas, 0)print(sum32(id))

http://www.lryc.cn/news/386816.html

相关文章:

  • 004 插入排序(lua)
  • 计算机网络 —— 基本概念
  • 高精度除法的实现
  • STM32CUBEMX配置USB虚拟串口
  • 安卓开发中margin和padding的区别
  • Symfony事件调度系统:掌控应用程序生命周期的钥匙
  • maven安装jar和pom到本地仓库
  • [leetcode]assign-cookies. 分发饼干
  • 如何轻松解决复杂文档格式转换问题
  • 日期类(java)
  • 【深度学习】C++ Tensorrt Yolov8 目标检测推理
  • 【项目日记(二)】搜索引擎-索引制作
  • K 近邻、K-NN 算法图文详解
  • Eclipse + GDB + J-Link 的单片机程序调试实践
  • 前端代码生成辅助工具
  • 静态库与动态库总结
  • 深入解析tcpdump:网络数据包捕获与分析的利器
  • 【漏洞复现】科立讯通信有限公司指挥调度管理平台uploadgps.php存在SQL注入
  • 什么是自然语言处理(NLP)?详细解读文本分类、情感分析和机器翻译的核心技术
  • 【linux】gcc快速入门教程
  • 【多维动态规划】Leetcode 97. 交错字符串【中等】
  • 【JavaScript脚本宇宙】精通前端开发:六大热门CSS框架详解
  • 开发技术-Java集合(List)删除元素的几种方式
  • c++ 递归
  • RedHat9 | podman容器
  • 边缘计算项目有哪些
  • 计算fibonacci数列每一项时所需的递归调用次数
  • 【教学类65-05】20240627秘密花园涂色书(中四班练习)
  • Python 学习之基础语法(一)
  • 日志分析-windows系统日志分析