使用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 元类使用说明
Dec 18 Python
Python 中迭代器与生成器实例详解
Mar 29 Python
Python使用正则表达式抓取网页图片的方法示例
Apr 21 Python
Tensorflow实现AlexNet卷积神经网络及运算时间评测
May 24 Python
python根据txt文本批量创建文件夹
Dec 08 Python
使用python来调用CAN通讯的DLL实现方法
Jul 03 Python
pycharm第三方库安装失败的问题及解决经验分享
May 09 Python
使用tensorflow实现VGG网络,训练mnist数据集方式
May 26 Python
python 如何使用find和find_all爬虫、找文本的实现
Oct 16 Python
python基于tkinter制作m3u8视频下载工具
Apr 24 Python
Python实现DBSCAN聚类算法并样例测试
Jun 22 Python
Python快速实现一键抠图功能的全过程
Jun 29 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 Session变量不能传送到下一页的解决方法
2009/11/27 PHP
解决PHP在DOS命令行下却无法链接MySQL的技术笔记
2010/12/29 PHP
检查用户名是否已在mysql中存在的php写法
2014/01/20 PHP
php去除字符串换行符示例分享
2014/02/13 PHP
PHP+ajaxfileupload+jcrop插件完美实现头像上传剪裁
2014/06/09 PHP
CodeIgniter控制器之业务逻辑实例分析
2016/01/20 PHP
PHP实现的曲线统计图表示例
2016/11/10 PHP
PHP Laravel 上传图片、文件等类封装
2017/08/16 PHP
用dom+xhtml+css制作的一个相册效果代码打包下载
2008/01/24 Javascript
JavaScript入门教程(12) js对象化编程
2009/01/31 Javascript
Mootools 1.2教程 滑动效果(Slide)
2009/09/15 Javascript
js判断undefined类型示例代码
2014/02/10 Javascript
EasyUI中实现form表单提交的示例分享
2015/03/01 Javascript
深入浅析JavaScript中with语句的理解
2016/05/12 Javascript
json的使用小结
2016/06/08 Javascript
NodeJs的fs读写删除移动监听
2017/04/28 NodeJs
JavaScript箭头函数_动力节点Java学院整理
2017/06/28 Javascript
jQuery easyui datagird编辑行删除行功能的实现代码
2018/09/20 jQuery
React和Vue中监听变量变化的方法
2018/11/14 Javascript
基于Vue2-Calendar改进的日历组件(含中文使用说明)
2019/04/14 Javascript
jQuery Ajax async=&gt;false异步改为同步时,解决导致浏览器假死的问题
2019/07/22 jQuery
vue悬浮可拖拽悬浮按钮的实例代码
2019/08/20 Javascript
解决layui批量传值到后台操作时出现传值为空的问题
2019/09/28 Javascript
Python导入txt数据到mysql的方法
2015/04/08 Python
Python中GIL的使用详解
2018/10/03 Python
Python+opencv 实现图片文字的分割的方法示例
2019/07/04 Python
python 录制系统声音的示例
2020/12/21 Python
英国家庭珠宝商:T. H. Baker
2018/02/08 全球购物
德国家具购物网站:Möbel Höffner
2019/08/26 全球购物
JAVA代码查错题
2014/10/10 面试题
婚纱摄影师求职信
2014/03/07 职场文书
老龄工作先进事迹
2014/08/15 职场文书
委托公证书样本
2015/01/23 职场文书
个人委托书范文
2015/01/28 职场文书
Redis三种集群模式详解
2021/10/05 Redis
python实现商品进销存管理系统
2022/05/30 Python