使用Python进行新浪微博的mid和url互相转换实例(10进制和62进制互算)


Posted in Python onApril 25, 2014

不过,status中包含了一个mid字段,通过mid,我们实际上是可以通过计算得到url的。

在开始计算之前有必要说明一下,什么是base62编码。它实际上就是十进制和62位进制的互换。对于62进制,从0数到9以后,10用小写字母a表示,接着数完26个字母,到z为35,然后36为大写字母A,一直到61为大写字母Z。所以,我们可以实现十进制数字base62编码的encode和decode。下面的代码实际上来自stackoverflow:

ALPHABET = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"def base62_encode(num, alphabet=ALPHABET):
    """Encode a number in Base X
    `num`: The number to encode
    `alphabet`: The alphabet to use for encoding
    """
    if (num == 0):
        return alphabet[0]
    arr = []
    base = len(alphabet)
    while num:
        rem = num % base
        num = num // base
        arr.append(alphabet[rem])
    arr.reverse()
    return ''.join(arr)
def base62_decode(string, alphabet=ALPHABET):
    """Decode a Base X encoded string into the number
    Arguments:
    - `string`: The encoded string
    - `alphabet`: The alphabet to use for encoding
    """
    base = len(alphabet)
    strlen = len(string)
    num = 0
    idx = 0
    for char in string:
        power = (strlen - (idx + 1))
        num += alphabet.index(char) * (base ** power)
        idx += 1
    return num

下面先说url到mid的转换。对于一个新浪微博url,它是形如:http://weibo.com/2991905905/z579Hz9Wr,中间的数字是用户的uid,重要的是后面的字符串“z579Hz9Wr”。它的计算其实也很简单,从后向前四个字符一组,就得到:

z
579H
z9Wr

将每个字符串用base62编码来decode,就可以得到它们的十进制数字分别为:

35
1219149
8379699

将它们拼起来就可以得到mid为:“3512191498379699”。这里要强调的是:对于除了开头的字符串,如果得到的十进制数字不足7位,需要在前面补足0。比如得到的十进制数分别为:35,33040,8906190,则需要在33040前面添上两个0。
代码如下:

def url_to_mid(url):
    '''
    >>> url_to_mid('z0JH2lOMb')
    3501756485200075L
    >>> url_to_mid('z0Ijpwgk7')
    3501703397689247L
    >>> url_to_mid('z0IgABdSn')
    3501701648871479L
    >>> url_to_mid('z08AUBmUe')
    3500330408906190L
    >>> url_to_mid('z06qL6b28')
    3500247231472384L
    >>> url_to_mid('yCtxn8IXR')
    3491700092079471L
    >>> url_to_mid('yAt1n2xRa')
    3486913690606804L
    '''
    url = str(url)[::-1]
    size = len(url) / 4 if len(url) % 4 == 0 else len(url) / 4 + 1
    result = []
    for i in range(size):
        s = url[i * 4: (i + 1) * 4][::-1]
        s = str(base62_decode(str(s)))
        s_len = len(s)
        if i < size - 1 and s_len < 7:
            s = (7 - s_len) * '0' + s
        result.append(s)
    result.reverse()
    return int(''.join(result))

mid转为url也就很简单了,对于一个mid,我们从后向前每7位一组,用base62编码来encode,拼起来即可。同样要注意的是,每7个一组的数字,除了开头一组,如果得到的62进制数字不足4位,需要补足0。

def mid_to_url(midint):
    '''
    >>> mid_to_url(3501756485200075)
    'z0JH2lOMb'
    >>> mid_to_url(3501703397689247)
    'z0Ijpwgk7'
    >>> mid_to_url(3501701648871479)
    'z0IgABdSn'
    >>> mid_to_url(3500330408906190)
    'z08AUBmUe'
    >>> mid_to_url(3500247231472384)
    'z06qL6b28'
    >>> mid_to_url(3491700092079471)
    'yCtxn8IXR'
    >>> mid_to_url(3486913690606804)
    'yAt1n2xRa'
    '''
    midint = str(midint)[::-1]
    size = len(midint) / 7 if len(midint) % 7 == 0 else len(midint) / 7 + 1
    result = []
    for i in range(size):
        s = midint[i * 7: (i + 1) * 7][::-1]
        s = base62_encode(int(s))
        s_len = len(s)
        if i < size - 1 and len(s) < 4:
            s = '0' * (4 - s_len) + s
        result.append(s)
    result.reverse()
    return ''.join(result)

运行doctest可以看到所有的测试用例都通过了。

最后其实我不太明白为什么新浪微博不直接把url包含在字段中,而新浪微博的开放平台也有很多不符合标准的地方,其实本文的内容并没有什么技术含量,不过就是让开发人员折腾一下。还有比如refresh token的问题等等,这里就不一一枚举了。

Python 相关文章推荐
python发送邮件实例分享
Jul 28 Python
学习Python3 Dlib19.7进行人脸面部识别
Jan 24 Python
Anaconda入门使用总结
Apr 05 Python
Pandas 合并多个Dataframe(merge,concat)的方法
Jun 08 Python
python实现Zabbix-API监控
Sep 17 Python
python学生信息管理系统(完整版)
Apr 05 Python
基于树莓派的语音对话机器人
Jun 17 Python
Python解析多帧dicom数据详解
Jan 13 Python
python爬取王者荣耀全皮肤的简单实现代码
Jan 31 Python
使用python实现下载我们想听的歌曲,速度超快
Jul 09 Python
基于python爬取梨视频实现过程解析
Nov 09 Python
Python常用配置文件ini、json、yaml读写总结
Jul 09 Python
Python time模块详解(常用函数实例讲解,非常好)
Apr 24 #Python
Python 时间操作例子和时间格式化参数小结
Apr 24 #Python
python抓取网页图片并放到指定文件夹
Apr 24 #Python
python字符串替换示例
Apr 24 #Python
python自动安装pip
Apr 24 #Python
python网络编程示例(客户端与服务端)
Apr 24 #Python
python使用PyFetion来发送短信的例子
Apr 22 #Python
You might like
第九节 绑定 [9]
2006/10/09 PHP
用php实现百度网盘图片直链的代码分享
2012/11/01 PHP
php返回相对时间(如:20分钟前,3天前)的方法
2015/04/14 PHP
PHP中in_array的隐式转换的解决方法
2018/03/06 PHP
jquery 应用代码 方便的排序功能
2010/02/06 Javascript
JavaScript 继承机制的实现(待续)
2010/05/18 Javascript
简单的Jquery全选功能
2013/11/07 Javascript
jquery插件pagination实现无刷新ajax分页
2015/09/30 Javascript
JS制作图形验证码实现代码
2020/10/19 Javascript
几句话带你理解JS中的this、闭包、原型链
2016/09/26 Javascript
Centos7 中 Node.js安装简单方法
2016/11/02 Javascript
原生js实现轮播图的示例代码
2017/02/20 Javascript
Js实现京东无延迟菜单效果实例(demo)
2017/06/02 Javascript
nodejs操作mongodb的填删改查模块的制作及引入实例
2018/01/02 NodeJs
浅谈ajax请求不同页面的微信JSSDK问题
2018/02/26 Javascript
基于Vue+element-ui 的Table二次封装的实现
2018/07/20 Javascript
swiper在vue项目中loop循环轮播失效的解决方法
2018/09/15 Javascript
json数据格式常见操作示例
2019/06/13 Javascript
[01:18]一目了然!DOTA2DotA快捷操作对比第一弹
2014/07/01 DOTA
[01:02:47]EG vs Secret 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.21.mp4
2020/07/19 DOTA
python计算N天之后日期的方法
2015/03/31 Python
利用python爬取斗鱼app中照片方法实例
2017/12/03 Python
python中字符串变二维数组的实例讲解
2018/04/03 Python
pandas通过loc生成新的列方法
2018/11/28 Python
PyQt5实现类似别踩白块游戏
2019/01/24 Python
Django stark组件使用及原理详解
2019/08/22 Python
python NumPy ndarray二维数组 按照行列求平均实例
2019/11/26 Python
Java ExcutorService优雅关闭方式解析
2020/05/30 Python
使用placeholder属性设置input文本框的提示信息
2020/02/19 HTML / CSS
拉斯维加斯酒店、演出、旅游、俱乐部及更多:Vegas.com
2019/02/28 全球购物
Hotels.com泰国:酒店预订网站
2019/11/20 全球购物
中学劳技课教师的自我评价
2014/02/05 职场文书
库房管理员岗位职责
2014/03/09 职场文书
优秀班组申报材料
2014/12/25 职场文书
2019预备党员转正申请书模板2篇!
2019/08/07 职场文书
关于mysql中时间日期类型和字符串类型的选择
2021/11/27 MySQL