简单测试了一下,如果用JSON,也就是python2.6以上自带的json处理库,效率还算可以:

1K的数据,2.9GHz的CPU,单核下每秒能dump:36898次。大约是pyamf的5倍。但数据量较大,约为pyamf的1.67倍(1101/656)。

start_time: 1370747463.77
loop_num: 36898
end_time:   1370747464.78

再看看simplejson,没有安装C扩展的情况下:

simplejson,没有安装C扩展,跑出的结果让我惊讶:

start_time: 1370748132.87
loop_num: 1361
end_time:   1370748133.88

效率如此之低下。

下面是测试代码:

  1. #! /usr/bin/env python
  2. #coding=utf-8
  3. import time
  4. import json
  5. test_data = {
  6. 'baihe': {
  7. 'name': unicode('百合', 'utf-8'),
  8. 'say': unicode('清新,淡雅,花香', 'utf-8'),
  9. 'grow_time': 0.5,
  10. 'fruit_time':  0.5,
  11. 'super_time': 0.5,
  12. 'total_time': 1,
  13. 'buy':{'gold':2, } ,
  14. 'harvest_fruit': 1,
  15. 'harvest_super': 1,
  16. 'sale': 1,
  17. 'level_need': 0,
  18. 'experience' : 2,
  19. 'exp_fruit': 1,
  20. 'exp_super': 1,
  21. 'used': True,
  22. },
  23. '1':{
  24. 'interval' : 0.3,
  25. 'probability' : {
  26. '98': {'chips' : (5, 25), },
  27. '2' : {'gem' : (1,1), },
  28. },
  29. },
  30. '2':{
  31. 'unlock' : {'chips':1000, 'FC':10,},
  32. 'interval' : 12,
  33. 'probability' : {
  34. '70': {'chips' : (120, 250), },
  35. '20': {'gem' : (1,1), },
  36. '10': {'gem' : (2,2), },
  37. },
  38. },
  39. 'one':{
  40. '10,5' :{'id':'m01', 'Y':1, 'msg':u'在罐子里发现了一个银币!',},
  41. '3,7'  :{'id':'m02', 'Y':10,'msg':u'发现了十个银币!好大一笔钱!',},
  42. '15,5' :{'id':'m03', 'Y':2, 'msg':u'一只老鼠跑了过去',},
  43. '7,4'  :{'id':'m04', 'Y':4, 'msg':u'发现了四个生锈的银币……',},
  44. '2,12' :{'id':'m05', 'Y':6, 'msg':u'六个闪亮的银币!',},
  45. },
  46. }
  47. start_time = time.time()
  48. print "start_time:", start_time
  49. j = 1
  50. while True:
  51. j += 1
  52. a = json.dumps(test_data)
  53. data_length = len(a)
  54. end_time = time.time()
  55. if end_time - start_time >= 1 :
  56. break
  57. print "loop_num:", j
  58. print "end_time:  ",end_time
  59. print data_length ,a

总结:python自带的json,性能可以接受。simplejson,如果没有C扩展加速,效率极其低下。

python JSON性能测试与simplejson对比的更多相关文章

  1. Python - json和simplejson比较(转)

    From:https://stackoverflow.com/questions/712791/what-are-the-differences-between-json-and-simplejson ...

  2. Python json和simplejson的使用

    在Python中,json数据和字符串的转换可以使用json模块或simplejson模块. json从Python2.6开始内置到了Python标准库中,我们不需要安装即可直接使用. simplej ...

  3. Python Locust性能测试框架实践

    [本文出自天外归云的博客园] Locust的介绍 Locust是一个python的性能测试工具,你可以通过写python脚本的方式来对web接口进行负载测试. Locust的安装 首先你要安装pyth ...

  4. 老李分享:Python开发性能测试脚本

    老李分享:Python开发性能测试脚本   测试开发工程师的工作主要是根据测试目标来完成,帮助测试人员完成测试目标,测试的业务需求是测试人员提出,但是由于环境的制约,手中没有性能测试工具的时候,性能测 ...

  5. 关于Python json解析过程遇到的TypeError: expected string or buffer

    关于Python json解析过程遇到的问题:(爬取天气json数据所遇到的问题http://tianqi.2345.com/) part.1 url——http://tianqi.2345.com/ ...

  6. Python json格式处理

    Python json格式处理 首先放一段代码 import requests import jsonpath import json f=open('ip.txt','r',encoding='ut ...

  7. python json基础学习01

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' import json #全称(javascript object  ...

  8. python json数据的转换

    1  Python数据转json字符串 import json json_str = json.dumps(py_data) 参数解析: json_str = json.dumps(py_data,s ...

  9. python大法好——python json

    Python JSON 本章节我们将为大家介绍如何使用 Python 语言来编码和解码 JSON 对象. JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式, ...

随机推荐

  1. 如何进bat

    既然是要谈如何进入BAT,那么咱们就从面试的角度来谈学习这件事,会谈谈一流互联网公司对于Java后端程序员的要求,相应的,也会谈谈如何达到这样的要求. 为了简单起见,这些要求分为三个层次,分别为基本要 ...

  2. [转]Groovy One Liners to Impress Your Friends

    Link:http://arturoherrero.com/2011/06/04/10-groovy-one-liners-to-impress-your-friends/ I find that c ...

  3. 读经典——《CLR via C#》(Jeffrey Richter著) 笔记_友元程序集

    [应用场景] 程序集A访问程序集B定义的Internal访问类型的类的成员. [使用方式] 在构建程序集B的时候,引入System.Runtime.CompilerServices,以此来添加Inte ...

  4. ajax提交文件file 单个文件上传

    转载: https://blog.csdn.net/u012867699/article/details/78357401

  5. 使用spyder编译器单步调试python

    1.将需要进行单步调试的函数在脚本中进行调用(十分重要的一步).由于python是解释型语言,在进行单步调试的时候需要告诉系统你使用了这个函数,单步调试才会进入你所需要调式的函数.如下图所示,我们定义 ...

  6. 2013 New available ICOM A2 Diagnostic & Programming For BMW ICOM A2+B+C

    AUTONUMEN.COM offer best price New ICOM A2 Diagnostic & Programming For BMW ICOM A2+B+C. bmw ico ...

  7. ssis error at other ssis.pipeline "ole db destination" failed validation and returned validation status

    我在修改一个ssis的包,发现这个destination的表被改过了.所以就重建了表.就导致了这个错误. 打开包重新检查下表结构的匹配就好了

  8. vue的watch详细用法

    https://www.cnblogs.com/shiningly/p/9471067.html https://www.jb51.net/article/139282.htm

  9. vue vue-resource网络请求

    在使用get/post 网络请求,需要下载插件 "vue-resource" npm install vue-resource -s 在路由要导入及注册 import Vue fr ...

  10. SQLiteOpenHelper 升级onUpgrade 的调用问题

    onUpgrade 的调用次数问题 比如说现在数据库版本是1,然后此时我修改代码定数据库版本为5. 那么系统在调用onUpgrade的时候是只调用一次(oldVersion == 1, newVers ...