Python语法资料汇总

[size=large][color=blue]1、python2转python3[/color][/size]
python2和python3语法互不兼容!!!
还好python提供了工具!
要转换一个文件夹及其子文件夹中的文件,只需要一句话:
cmd中输入:
python  pythong安装目录/Scripts/2to3-script.py -w  要转的文件夹名称
#例如python E:/Anaconda3/Scripts/2to3-script.py -w assignment1py3
#其中assignment1py3为文件夹!

其中 -w 表示转换完了写回到原文件,,所以执行前最好是复制一个副本出来
如果要转的文件不是以.py结尾的,,则需要一个个文件去敲代码,比如
python  E:/Anaconda3/Scripts/2to3-script.py -w knn.ipynb



[size=large][color=blue]2、python入门资料[/color][/size]
cs231n的python介绍:[url]http://cs231n.github.io/python-numpy-tutorial/[/url]

Numpy for Matlab users:[url]https://docs.scipy.org/doc/numpy-dev/user/numpy-for-matlab-users.html[/url]
numpy推荐直接用ANACONDA套装:[url]https://www.continuum.io/downloads[/url]


[size=large][color=blue]3、python文件处理[/color][/size]
缓存的大小可以在open时设置:
[url]http://stackoverflow.com/questions/3167494/how-often-does-python-flush-to-a-file[/url]
示例代码如下:
def processFileLineByLine(filename,outfilename, lineFunc, headLineFunc=None,encoding='utf-8'):
'''
将filename中的每一行通过lineFunc转换后输出到outfilename文件中,
如果对首行有特殊的处理需求,可以设置headLineFunc
'''
import codecs
f = codecs.open(filename, 'r', encoding);
fo = codecs.open(outfilename, 'w', encoding,buffering=1024*1024);
if(headLineFunc!=None):
fo.write(headLineFunc(f.readline()));

while True:
lines=f.readlines(2048);
if(not lines or len(lines)==0):
break;
for line in lines:
fo.write(lineFunc(line));
f.close();
fo.close();
def changeSplitChar2(filename,outfilename,encoding='utf-8',oldSplitChar='\t',newSplitChar=','):
def chchar(line):
return line.replace(oldSplitChar,newSplitChar);
processFileLineByLine(filename, outfilename, lineFunc=chchar, encoding=encoding)



[size=large][color=blue]4、iterator & generator[/color][/size]
参见:[url]http://anandology.com/python-practice-book/iterators.html[/url]
generator 是 iterator 的简化版(代码量减少),本质完全相同。
generator以函数形式编写,, 代码运行到 yield x 时输出一个x ,,相当于next(it);
注意: python3中采用 next(it) , 而非 it.next()的形式;

可以采用 list(it) 生成list

[size=large][color=blue]5、python 函数的default value是共享的[/color][/size]
[url]http://stackoverflow.com/questions/4841782/python-constructor-and-default-value[/url]
[url]http://stackoverflow.com/questions/1132941/least-astonishment-in-python-the-mutable-default-argument[/url]
[url]http://effbot.org/zone/default-values.htm[/url]
def append(i,a=None):
if(a is None): a=list()
a.append(i);
return a;

# a 在def语句执行时初始化,所以是共享的。。。。。
def append_Wrong(i,a=[]):
a.append(i)
return a;

if __name__ == '__main__':
print(append(1)) #[1]
print(append(2)) #[2]

print(append_Wrong(1)) #[1]
print(append_Wrong(2)) #[1, 2]


[size=large][color=blue]6、列出所有变量[/color][/size]
参见[url]http://stackoverflow.com/questions/633127/viewing-all-defined-variables[/url]
[list]
[*]vars() 列出所有变量,为一个dict, for varName, varValue in vars().items()...
[*]dir() 列出所有变量名, 之后可以通过eval(variableName) 来获取变量
[*]globals() 全局变量
[*]locals() 局部变量
[/list]

[size=large][color=blue]6、python2 的ascii’ codec can’t encode[/color][/size]
通过以下语句修改全局设置,参见(内容很详细):[url]http://in355hz.iteye.com/blog/1860787[/url]
import sys
reload(sys)
sys.setdefaultencoding('utf-8')

虽然那篇博文中不推荐这么做,但我觉着这个方案没什么不好的,比较utf-8是兼容ascii的,既然原本为ascii的编解码器,那么换为utf-8的编解码器应该没任何问题。

[size=large][color=blue]7、python命令行环境变量设置[/color][/size]
[list]
[*]PYTHONIOENCODING=UTF-8 python ***.py #更改编码
[*]export PYTHONPATH=$PYTHONPATH:newpath/subfolder #增加库路径
[/list]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值