使用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 相关文章推荐
python3图片转换二进制存入mysql
Dec 06 Python
Python使用新浪微博API发送微博的例子
Apr 10 Python
python动态网页批量爬取
Feb 14 Python
Python实现在线暴力破解邮箱账号密码功能示例【测试可用】
Sep 06 Python
python利用paramiko连接远程服务器执行命令的方法
Oct 16 Python
好的Python培训机构应该具备哪些条件
May 23 Python
Python Logging 日志记录入门学习
Jun 02 Python
Python matplotlib通过plt.scatter画空心圆标记出特定的点方法
Dec 13 Python
Python面向对象程序设计OOP深入分析【构造函数,组合类,工具类等】
Jan 05 Python
python pexpect ssh 远程登录服务器的方法
Feb 14 Python
关于pandas的离散化,面元划分详解
Nov 22 Python
Python爬虫谷歌Chrome F12抓包过程原理解析
Jun 04 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 pack与unpack 摸板字符字符含义
2009/10/29 PHP
关于php mvc开发模式的感想
2011/06/28 PHP
PHP获取一个字符串中间一部分字符的方法
2014/08/19 PHP
laravel实现上传图片的两种方式小结
2019/10/12 PHP
在chrome浏览器中,防止input[text]和textarea在聚焦时出现黄色边框的解决方法
2011/05/24 Javascript
javascript写的简单的计算器,内容很多,方法实用,推荐
2011/12/29 Javascript
DWZ table的原生分页浅谈
2013/03/01 Javascript
基于javascript 闭包基础分享
2013/07/10 Javascript
用jquery修复在iframe下的页面锚点失效问题
2014/08/22 Javascript
Vue组件BootPage实现简单的分页功能
2016/09/12 Javascript
微信小程序 实战小程序实例
2016/10/08 Javascript
web打印小结
2017/01/11 Javascript
canvas雪花效果核心代码分享
2017/02/19 Javascript
JS组件系列之MVVM组件 vue 30分钟搞定前端增删改查
2017/04/28 Javascript
基于Vue实现后台系统权限控制的示例代码
2017/08/29 Javascript
jQuery实现鼠标响应式淘宝动画效果示例
2018/02/13 jQuery
vue实现鼠标经过动画
2019/10/16 Javascript
Vue的data、computed、watch源码浅谈
2020/04/04 Javascript
python fabric实现远程操作和部署示例
2014/03/25 Python
python如何实现反向迭代
2018/03/20 Python
Python PIL图片添加字体的例子
2019/08/22 Python
浅谈Python3 numpy.ptp()最大值与最小值的差
2019/08/24 Python
python生成器/yield协程/gevent写简单的图片下载器功能示例
2019/10/28 Python
提升python处理速度原理及方法实例
2019/12/25 Python
对tensorflow中cifar-10文档的Read操作详解
2020/02/10 Python
最小二乘法及其python实现详解
2020/02/24 Python
python shapely.geometry.polygon任意两个四边形的IOU计算实例
2020/04/12 Python
Python devel安装失败问题解决方案
2020/06/09 Python
DRF框架API版本管理实现方法解析
2020/08/21 Python
New Balance德国官方网站:购买鞋子和服装
2019/08/31 全球购物
c/c++某大公司的两道笔试题
2014/02/02 面试题
.net工程师笔试题
2012/06/09 面试题
领导的自我鉴定
2013/12/28 职场文书
婚礼主持词
2014/03/13 职场文书
导游词之广州陈家祠
2019/10/21 职场文书
SQL Server中锁的用法
2022/05/20 SQL Server