使用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 提取文件的小程序
Jul 29 Python
在Python的Flask框架中实现全文搜索功能
Apr 20 Python
结合Python的SimpleHTTPServer源码来解析socket通信
Jun 27 Python
Python读csv文件去掉一列后再写入新的文件实例
Dec 28 Python
python3使用smtplib实现发送邮件功能
May 22 Python
python实现抖音点赞功能
Apr 07 Python
python主线程与子线程的结束顺序实例解析
Dec 17 Python
Python使用pymysql模块操作mysql增删改查实例分析
Dec 19 Python
关于windows下Tensorflow和pytorch安装教程
Feb 04 Python
Macbook安装Python最新版本、GUI开发环境、图像处理、视频处理环境详解
Feb 17 Python
解决Keras 自定义层时遇到版本的问题
Jun 16 Python
python遍历路径破解表单的示例
Nov 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
ThinkPHP3.2.2的插件控制器功能
2015/03/05 PHP
深入解析WordPress中加载模板的get_template_part函数
2016/01/11 PHP
php-beanstalkd消息队列类实例分享
2017/07/19 PHP
PHP如何将图片文件上传到另外一台服务器上
2019/08/26 PHP
JavaScript的面向对象(二)
2006/11/09 Javascript
JS+CSS实现可以凹陷显示选中单元格的方法
2015/03/02 Javascript
jquery实现页面虚拟键盘特效
2015/08/08 Javascript
JavaScript脚本判断蜘蛛来源的方法
2015/09/22 Javascript
谈谈JavaScript类型系统之Math
2016/01/06 Javascript
javascript中的作用域和闭包详解
2016/01/13 Javascript
js+canvas绘制五角星的方法
2016/01/28 Javascript
jQuery Mobile框架中的表单组件基础使用教程
2016/05/17 Javascript
基于javascript实现按圆形排列DIV元素(二)
2016/12/02 Javascript
jQuery实现判断上传图片类型和大小的方法示例
2018/04/11 jQuery
JS sort排序详细使用方法示例解析
2020/09/27 Javascript
Vue 数据绑定的原理分析
2020/11/16 Javascript
swiper实现导航滚动效果
2020/12/13 Javascript
Python设计足球联赛赛程表程序的思路与简单实现示例
2016/06/28 Python
Python语言描述连续子数组的最大和
2018/01/04 Python
python3爬取淘宝信息代码分析
2018/02/10 Python
Python根据已知邻接矩阵绘制无向图操作示例
2018/06/23 Python
Python3.7中安装openCV库的方法
2018/07/11 Python
CSS3中:nth-child和:nth-of-type的区别深入理解
2014/03/10 HTML / CSS
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
2016/12/14 HTML / CSS
Max&Co官网:意大利年轻女性时尚品牌
2017/05/16 全球购物
东南亚旅游平台:The Trip Guru
2018/01/01 全球购物
一套Delphi的笔试题二
2013/05/11 面试题
考博自荐信
2013/10/25 职场文书
国际经济贸易专业推荐信
2013/11/06 职场文书
大二学生学习个人自我评价
2014/01/19 职场文书
音乐器材管理制度
2014/01/31 职场文书
资助贫困学生倡议书
2014/05/16 职场文书
优秀大专毕业生求职信
2014/08/04 职场文书
西双版纳导游词
2015/02/03 职场文书
休学证明范本
2015/06/19 职场文书
「天才王子的赤字国家重生术」妮妮姆·拉雷粘土人开订
2022/03/21 日漫