py版的原生Json解析器

之前的博客已经介绍过py和java-json的关系,以及他们的json包,之前写了Java版本的原生Json解析器:

http://blog.csdn.net/qq_34417408/article/details/78563602

这段时间捡起了好久没用的python,试着写py版的;

思考之前的java版,有枚举,有类,有继承,有接口;虽然在python中都可以通过引入模块,覆盖等手段实现。但是在py版的Json 是可以不要枚举的,接口的,这也算是py的优点,简单粗暴不繁琐。当然在后期维护的时候就比较尴尬了;

python的枚举

将枚举去掉之后,Java中的list对应py 的集合,Json对象对应Py的字典;
由于语法的不同java和python 的一些结构需要变化,简单说,java的do While用py 的while if 替换,在Ture/False,大小写都有区别,包括Null-None。

     while True:
            #print(reader)
            c=self.file.read(1)
            print(not self.isSpace(c))
            if not self.isSpace(c):
                break

还有一点是,python在io中支持的是文件的读取,主要有read()/readline()函数,在控制台输入是input/raw_input(),在解析器中需要一次读取字节流,而在python中我并没有相关的类,于是我就传入file-url参数,通过将测试数据通过控制台写入文件中,传入文件的地址作为方法的参数,进而在类中进行文件的read(1)进行字节的依次读取;

if __name__=="__main__":
    testValue=raw_input('请输入测试数据:')
    file=open('G:/pycharm_workspace/JsonPython/test.txt','w')
file.write(testValue)
file.close()
url='G:/pycharm_workspace/JsonPython/test.txt'
tokenizer=Tokenizer(url)    #传入文件的url
 def __init__(self,url):
        self.url=url
        self.file = open(url, 'r')   #类中打开文件,进行读取

另一处是,在java中的read() 是在读取结束后返回值为-1;而在python进行字节读取过程中read(1)[ps:此为py中os中的read(),不同于java.io.read()]最后返回并不是-1;返回为’/n’;

    elif ord(c)==10:     #换行符的ascii为10
            return Token('TokenType_END_DOC','EOF')

在java中对对象属性做的一些封装,在python中也是可以忽略的,直接调用即可。
总体来看主要是py和java的语法差别,当然上篇博客已经介绍在py中的json处理,这里只是简单的语法替换,当然,实践出真知,还是需要具体的编码实现,尤其是好久没用py,编码时还是出现些许麻烦,上面只是附了几个改变而已,编码之后就会发现,py真的是易编码,简单粗暴不繁琐。具体源码见GitHub(IDE:PyCharm):
https://github.com/weiyanyanyan/JsonPython
附上测试截图:

输入测试数据

py版的原生Json解析器_第1张图片

当然结果和输入之间有乱入我的调试输出;

这里写图片描述

这里写图片描述

正在不断学习,有不足之处请指出,共同进步,谢谢!

你可能感兴趣的:(Python,JAVA,python,java,json,json解析)