使用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的Zato发送AMQP消息的教程
Apr 16 Python
Python的Flask框架中使用Flask-Migrate扩展迁移数据库的教程
Jun 14 Python
Python django实现简单的邮件系统发送邮件功能
Jul 14 Python
Python 判断 有向图 是否有环的实例讲解
Feb 01 Python
利用Python实现原创工具的Logo与Help
Dec 03 Python
对Python _取log的几种方式小结
Jul 25 Python
pycharm重命名文件的方法步骤
Jul 29 Python
python图的深度优先和广度优先算法实例分析
Oct 26 Python
Python高级特性之闭包与装饰器实例详解
Nov 19 Python
python列表返回重复数据的下标
Feb 10 Python
Pytorch 使用CNN图像分类的实现
Jun 16 Python
Python使用Opencv实现边缘检测以及轮廓检测的实现
Dec 31 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
php 日期时间处理函数小结
2009/12/18 PHP
php的list()的一步操作给一组变量进行赋值的使用
2011/05/18 PHP
通过5个php实例细致说明传值与传引用的区别
2012/08/08 PHP
php的数组与字符串的转换函数整理汇总
2013/07/18 PHP
ThinkPHP中limit()使用方法详解
2016/04/19 PHP
php可变长参数处理函数详解
2017/02/22 PHP
利用PHP实现一个简单的用户登记表示例
2017/04/25 PHP
键盘 keycode的值 javascript时触发事件时很有用的要素
2009/11/02 Javascript
JS获得URL超链接的参数值实例代码
2013/06/21 Javascript
jquery 字符串切割函数substring的用法说明
2014/02/11 Javascript
javascript实现的平方米、亩、公顷单位换算小程序
2014/08/11 Javascript
Javascript数组与字典用法分析
2014/12/13 Javascript
jQuery form插件的使用之处理server返回的JSON, XML,HTML数据
2016/01/26 Javascript
js 获取经纬度的实现方法
2016/06/20 Javascript
js利用appendChild对标签进行排序的实现方法
2016/10/16 Javascript
JavaScript reduce和reduceRight详解
2016/10/24 Javascript
angularJs使用$watch和$filter过滤器制作搜索筛选实例
2017/06/01 Javascript
canvas基础绘制-绚丽倒计时的实例
2017/09/17 Javascript
vue打包后显示空白正确处理方法
2017/11/01 Javascript
移动端滑动切换组件封装 vue-swiper-router实例详解
2018/11/25 Javascript
微信小程序实现搜索功能
2020/03/10 Javascript
vue-video-player实现实时视频播放方式(监控设备-rtmp流)
2020/08/10 Javascript
[03:01]DOTA2英雄基础教程 露娜
2014/01/07 DOTA
pyqt和pyside开发图形化界面
2014/01/22 Python
windows下python模拟鼠标点击和键盘输示例
2014/02/28 Python
Python基于Matplotlib库简单绘制折线图的方法示例
2017/08/14 Python
Python实现迭代时使用索引的方法示例
2018/06/05 Python
python将视频转换为全字符视频
2019/04/26 Python
Python基于staticmethod装饰器标示静态方法
2020/10/17 Python
佛罗里达州印第安河新鲜水果:Hale Groves
2017/02/20 全球购物
健康监测猫砂:Pretty Litter
2017/05/25 全球购物
学生学习总结的自我评价
2013/10/22 职场文书
文明礼仪演讲稿
2014/05/12 职场文书
企业法人授权委托书
2014/09/25 职场文书
预备党员群众意见
2015/06/01 职场文书
Oracle中update和select 关联操作
2022/01/18 Oracle