使用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 ZipFile模块详解
Nov 01 Python
一个超级简单的python web程序
Sep 11 Python
用Python写飞机大战游戏之pygame入门(4):获取鼠标的位置及运动
Nov 05 Python
python3实现TCP协议的简单服务器和客户端案例(分享)
Jun 14 Python
Python图像处理之图像的缩放、旋转与翻转实现方法示例
Jan 04 Python
python获取磁盘号下盘符步骤详解
Jun 19 Python
Python正则表达式匹配数字和小数的方法
Jul 03 Python
Pytorch 实现自定义参数层的例子
Aug 17 Python
Python图像处理模块ndimage用法实例分析
Sep 05 Python
Python实现钉钉订阅消息功能
Jan 14 Python
python中加背景音乐如何操作
Jul 19 Python
用python对excel进行操作(读,写,修改)
Dec 25 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
WordPress中调试缩略图的相关PHP函数使用解析
2016/01/07 PHP
PHP sleep()函数, usleep()函数
2016/08/25 PHP
php getcwd与dirname(__FILE__)区别详解
2016/09/24 PHP
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
JavaScript下申明对象的几种方法小结
2008/10/02 Javascript
jquery next nextAll nextUntil siblings的区别介绍
2013/10/05 Javascript
js动态调用css属性的小规律及实例说明
2013/12/28 Javascript
推荐 21 款优秀的高性能 Node.js 开发框架
2014/08/18 Javascript
jQuery手机浏览器中拖拽动作的艰难性分析
2015/02/04 Javascript
js钢琴按钮波浪式图片排列效果代码分享
2015/08/26 Javascript
JS实现随页面滚动显示/隐藏窗口固定位置元素
2016/02/26 Javascript
JavaScript版经典游戏之扫雷游戏完整示例【附demo源码下载】
2016/12/12 Javascript
jquery mobile移动端幻灯片滑动切换效果
2020/04/15 Javascript
利用ES6实现单例模式及其应用详解
2017/12/09 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
2018/01/10 Javascript
浅谈开发eslint规则
2018/10/01 Javascript
浅析JS中什么是自定义react数据验证组件
2018/10/19 Javascript
vue中v-for通过动态绑定class实现触发效果
2018/12/06 Javascript
使用webpack构建应用的方法步骤
2019/03/04 Javascript
vue v-for循环重复数据无法添加问题解决方法【加track-by='索引'】
2019/03/15 Javascript
python访问抓取网页常用命令总结
2017/04/11 Python
python 读取文本文件的行数据,文件.splitlines()的方法
2018/07/12 Python
python+selenium 定位到元素,无法点击的解决方法
2019/01/30 Python
基于python的BP神经网络及异或实现过程解析
2019/09/30 Python
PyCharm导入python项目并配置虚拟环境的教程详解
2019/10/13 Python
python time()的实例用法
2020/11/03 Python
CSS3简单实现照片墙
2014/12/12 HTML / CSS
CSS3+js实现简单的时钟特效
2015/03/18 HTML / CSS
CSS3中各种颜色属性的使用教程
2016/05/17 HTML / CSS
高中毕业自我评价
2014/02/08 职场文书
cf收人广告词
2014/03/14 职场文书
微电影大赛策划方案
2014/06/05 职场文书
学困生帮扶工作总结
2015/08/13 职场文书
Python如何解决secure_filename对中文不支持问题
2021/07/16 Python
记一次Mysql不走日期字段索引的原因小结
2021/10/24 MySQL
Python机器学习应用之工业蒸汽数据分析篇详解
2022/01/18 Python