使用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 相关文章推荐
浅谈tensorflow1.0 池化层(pooling)和全连接层(dense)
Apr 27 Python
Python实现的txt文件去重功能示例
Jul 07 Python
python查看模块,对象的函数方法
Oct 16 Python
python检测IP地址变化并触发事件
Dec 26 Python
opencv python统计及绘制直方图的方法
Jan 21 Python
用Anaconda安装本地python包的方法及路径问题(图文)
Jul 16 Python
详解Python中正则匹配TAB及空格的小技巧
Jul 26 Python
wxPython:python首选的GUI库实例分享
Oct 05 Python
Python中itertools的用法详解
Feb 07 Python
使用tensorflow实现矩阵分解方式
Feb 07 Python
Python实现动态循环输出文字功能
May 07 Python
Python实现8种常用抽样方法
Jun 27 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&amp;mysql(一)
2006/10/09 PHP
建站常用13种PHP开源CMS比较
2009/08/23 PHP
php筛选不存在的图片资源
2015/04/28 PHP
thinkPHP3.2.3实现阿里大于短信验证的方法
2018/06/06 PHP
详解php中curl返回false的解决办法
2019/03/18 PHP
关于hashchangebroker和statehashable的补充文档
2011/08/08 Javascript
Javascript实现DIV滚动自动滚动到底部的代码
2012/03/01 Javascript
图片动画横条广告带上下滚动的JS代码
2013/10/25 Javascript
用console.table()调试javascript
2014/09/04 Javascript
JavaScript阻止浏览器返回按钮的方法
2015/03/18 Javascript
JS+CSS实现自适应选项卡宽度的圆角滑动门效果
2015/09/15 Javascript
JS控制文本域只读或可写属性的方法
2016/06/24 Javascript
详解基于 axios 的 Vue 项目 http 请求优化
2017/09/04 Javascript
详解require.js配置路径的用法和css的引入
2017/09/06 Javascript
详解如何将 Vue-cli 改造成支持多页面的 history 模式
2017/11/20 Javascript
javascript数组的定义及操作实例
2019/11/10 Javascript
JS插入排序简单理解与实现方法分析
2019/11/25 Javascript
使用Vant完成通知栏Notify的提示操作
2020/11/11 Javascript
[03:56]还原FTP电影首映式 DOTA2群星拼出遗迹世界
2014/03/26 DOTA
[00:48]DOTA2国际邀请赛公开赛报名开始 扫码开启逐梦之旅
2018/06/06 DOTA
Python抓取京东图书评论数据
2014/08/31 Python
详解Python中的四种队列
2018/05/21 Python
python 匹配url中是否存在IP地址的方法
2018/06/04 Python
Python生成器的使用方法和示例代码
2019/03/04 Python
Python Datetime模块和Calendar模块用法实例分析
2019/04/15 Python
Python进阶之迭代器与迭代器切片教程
2020/01/29 Python
Python configparser模块封装及构造配置文件
2020/08/07 Python
经管应届生求职信
2013/11/17 职场文书
毕业自我评价
2014/02/05 职场文书
募捐倡议书
2014/04/14 职场文书
技术合作协议书范本
2014/04/18 职场文书
公安局负责人查摆问题及整改方案
2014/09/27 职场文书
2014年党员干部四风问题自我剖析材料
2014/09/29 职场文书
Nginx tp3.2.3 404问题解决方案
2021/03/31 Servers
Python批量将csv文件转化成xml文件的实例
2021/05/10 Python
Mysql表数据比较大情况下修改添加字段的方法实例
2022/06/28 MySQL