使用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 相关文章推荐
Windows下用py2exe将Python程序打包成exe程序的教程
Apr 08 Python
Python安装第三方库及常见问题处理方法汇总
Sep 13 Python
Python 私有函数的实例详解
Sep 11 Python
浅谈python中列表、字符串、字典的常用操作
Sep 19 Python
Python反爬虫技术之防止IP地址被封杀的讲解
Jan 09 Python
Python定义函数功能与用法实例详解
Apr 08 Python
TensorFlow实现从txt文件读取数据
Feb 05 Python
Python编程快速上手——选择性拷贝操作案例分析
Feb 28 Python
关于Python Tkinter Button控件command传参问题的解决方式
Mar 04 Python
python爬取音频下载的示例代码
Oct 19 Python
详解基于python的图像Gabor变换及特征提取
Oct 26 Python
Python-OpenCV教程之图像的位运算详解
Jun 21 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删除HTMl标签的三种解决方法
2013/06/30 PHP
php实现的CSS更新类实例
2014/09/22 PHP
Laravel学习教程之本地化模块
2017/08/18 PHP
Yii2框架自定义类统一处理url操作示例
2019/05/25 PHP
js字母大小写转换实现方法总结
2013/11/13 Javascript
JS实现网站菜单拖拽移位效果的方法
2015/09/24 Javascript
Node.js中使用jQuery的做法
2016/08/17 Javascript
html5+CSS 实现禁止IOS长按复制粘贴功能
2016/12/28 Javascript
微信小程序 登陆流程详细介绍
2017/01/17 Javascript
jQuery实现多张图片上传预览(不经过后端处理)
2017/04/29 jQuery
webstorm添加vue.js支持的方法教程
2017/07/05 Javascript
利用JavaScript实现栈的数据结构示例代码
2017/08/02 Javascript
JS对象序列化成json数据和json数据转化为JS对象的代码
2017/08/23 Javascript
Angular4学习教程之DOM属性绑定详解
2018/01/04 Javascript
Node.js 使用request模块下载文件的实例
2018/09/05 Javascript
js实现网页同时进行多个倒计时功能
2019/02/25 Javascript
jQuery 选择器用法基础入门示例
2020/01/04 jQuery
用Nodejs实现在终端中炒股的实现
2020/10/18 NodeJs
[01:21]辉夜杯战队访谈宣传片—CDEC
2015/12/25 DOTA
[06:53]2018DOTA2国际邀请赛寻真——为复仇而来的Newbee
2018/08/15 DOTA
[01:12:08]LGD vs OG 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.24
2019/09/10 DOTA
python翻译软件实现代码(使用google api完成)
2013/11/26 Python
window下eclipse安装python插件教程
2017/04/24 Python
Python多层装饰器用法实例分析
2018/02/09 Python
详解Python做一个名片管理系统
2019/03/14 Python
python pandas时序处理相关功能详解
2019/07/03 Python
解析Python3中的Import
2019/10/13 Python
调用其他python脚本文件里面的类和方法过程解析
2019/11/15 Python
将labelme格式数据转化为标准的coco数据集格式方式
2020/02/17 Python
django模型类中,null=True,blank=True用法说明
2020/07/09 Python
孤独星球出版物:Lonely Planet Publications
2018/03/17 全球购物
面向对象编程是如何提高软件开发水平的
2014/05/06 面试题
物业管理员岗位职责范文
2013/11/25 职场文书
2014年端午节演讲稿范文
2014/05/23 职场文书
2016新教师岗前培训心得体会
2016/01/08 职场文书
教师节作文之小学四年级
2019/09/03 职场文书