导语:

Python编程博大精深,知识点众多,需要先整体上了解python的一些基本用法之后再去对每一个知识点细细研究,这样学习的速度会快很多。所以下面就先看一些python事先需要知道的基本知识。

交互模式编程:

所谓交互就是跟用户也就是我们使用python的人交互,你给出指令或代码,python解释器给出结果。
调用解释器不经过脚本文件作为参数,显示以下提示:

# python
Python 2.7.10 (default, Jul 14 2015, 19:46:27)
[GCC 4.2.1 Compatible Apple LLVM 6.0 (clang-600.0.39)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>>
键入下列文字在Python提示符,然后按Enter键:
>>> print "Hello, Python!"      #python2.0
>>> print ("Hello, Python!")    #python3.0
Hello, Python!                     

强烈推荐使用ipython,其安装方式见:http://blog.51cto.com/fklinux/2046741

脚本模式编程:

所谓脚本编程,即把python指令或代码写入文本文件当中,再给这些指令指定一个命令解释器,这个文件文件就是python脚本了。
比如:写入如下代码在一个test.py文件

print "Hello, Python!"

运行程序:

python test.py

Hello, Python!

另一种方式执行Python脚本,修改后的test.py文件:
#!/usr/bin/python
print "Hello, Python!"

运行程序:

chmod +x test.py

#./test.py
Hello, Python!

脚本模式编程中使用中文

python默认使用ascii码,不支持中文,使用中文需要声明支持中文的字符集,一般是utf8,方式如下:

#!/usr/bin/python
#coding=utf8
#encoding:utf-8     
#_*_ coding:utf-8 _*_
print "你好中国!"

上面3种方式都可以
为什么有这么多写法?
python是按正则的方式检测你的字符集定义里面有没有他想要看到的东西,只要符合下面的正则即可:

coding[:=]\s*([-\w.]+)
[root@wing python]# cat a.py
#!/usr/bin/env python
#fdsf coding=utf8 fdaf    比如这里的fdsf fdaf是我随便乱写的 只要里面有coding utf8 等等就可以
print "中国你好"

注:python3中已经可以直接支持中文,不需要专门指定支持中文的字符集

Python标识符:

1. 用来标识一个变量,函数,类,模块或其他对象的名称。
2. 一个标识符开始以字母A到Z或a到z后跟零个或多个字母下划线(_)和数字(0〜9),Python标识符内不允许标点符号,如@、$、%等。
3. Python区分大小写。

标识符命名约定:

• 类名以大写字母以及所有其它标识符以小写字母。
• 开头单个前导下划线的标识符表示由该标识符约定的意思是私有的。
• 开头两个前导下划线的标识符表示一个强烈的私有的标识符。
• 如果标识符末尾还具有两个下划线结束时,该标识符是一个语言定义的特殊名称。

避免用下划线作为变量名的开始:

因为下划线对解释器有特殊意义,而且是内建标识符所使用的符号,建议程序员避免用下划线作为变量名的开始。
一般来讲,变量名'_xxx' 被看作是“私有的”,在模块或类外不可以使用。
当变量是私有的时候,用_xxx 来表示变量是很好的习惯。
因为变量名__xxx__对 Python 来说有特殊含义,对于普通的变量应当避免这种命名风格

保留字:

保留字不可以被用作常量或变量,或任何其它标识符。所有Python关键字只包含小写字母。
查询当前版本python中所有关键字:

>> import keyword #如果系统中没有这个模块,需要安装python-docs
>> keyword.kwlist
['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

判断是否为关键字:

>> keyword.iskeyword ('False')
此时将返回True

行和缩进:

学习Python时,遇到的第一个需要注意的地方是,不使用括号来表示代码的类和函数定义块或流程控制。代码块是由行缩进,这是严格执行表示方式。
缩进位的数目是可变的,但是在块中的所有语句必须缩进相同的量。在这个例子中,两个功能块都很好使用:

if True:
    print "True"
else:
        print "False"

在本例中的第二块将产生一个错误:

if True:
        print "Answer"
        print "True"
else:
        print "Answer"
    print "False"

因此,在Python中所有的连续线缩进的空格数同样的会结成块。

多行语句:

Python语句通常用一个新行结束。 但是,Python允许使用续行字符()来表示,该行应该继续下去(跨行)。

例如:

total = (item_one + 
                item_two + 
                item_three)

包含在[],{}或()括号内的陈述并不需要使用续行符。
例如:

days = ['Monday', 'Tuesday', 'Wednesday',
        'Thursday', 'Friday']

可以使用三引号"""或'''来打印多行语句,写什么格式就打印什么格式。
比如:

print('''hello this
is
a
test 多行语句''')

打印结果如下:

hello this
is
a
test 多行语句

继续符( \ ):

Python 语句,一般使用换行分隔,也就是说一行一个语句。一行过长的语句可以使用反斜 杠( \ ) 分解成几行,比如:

if (weather_is_hot == 1) and \
(shark_warnings == 0):
send_goto_beach_mesg_to_pager()

引号:

Python可以使用单引号('),双引号(“)和三('''或”””)引号,以表示字符串常量,只要是同一类型的引号开始和结束的字符串。三重引号可以用于跨越多个行的字符串。
例如:

word = 'word'
sentence = "This is a sentence."
paragraph = """This is a paragraph. It is
made up of multiple lines and sentences."""

注释:

单行注释:
一个井号(#),“#”号之后字符到本行结束都是注释,Python解释器会忽略它们。比如:

#!/usr/bin/python
# First comment
print "Hello, Python!"  # second comment
运行结果:
Hello, Python!

使用三引号完成多行注释:

'''
comment1
comment2
''''

等待用户:

方式1:raw_input()

程序的下面一行显示的提示,按回车键退出,等待用户按下回车键:
#!/usr/bin/python
raw_input("Press the enter key to exit.")
一旦用户按下键时,程序结束。这是一个很好的技巧,保持一个交互式对话,直到用户完成应用程序运行。

方式2:input()

上面两种等待用户输入的方式区别是:

raw_input不解释用户输入
input会解释用户的输入

在一行中多个语句:

分号( ; ) 允许在单行写入多条语句,不管语句是否启动一个新的代码块。下面是使用分号示例:
import sys; x = 'foo'; sys.stdout.write(x + '')

多个语句组作为套件:

一组单独的语句, 在Python单一的代码块被称为序列。复杂的语句,如if, while, def, and class,那些需要一个标题行和套件。
标题行开始与声明(关键字),并终止与冒号(:),接着是一个或多个线构成该套件。例如:

if expression : 
     suite
elif expression : 
     suite 
else : 
     suite

命令行参数:

很多程序可以运行,它们提供有关如何运行的一些基本信息。 Python中可以使用 -h 做到这一
点:

 $ python -h
        usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...
        Options and arguments (and corresponding environment variables):
        -c cmd : program passed in as string (terminates option list)
        -d     : debug output from parser (also PYTHONDEBUG=x)
        -E     : ignore environment variables (such as PYTHONPATH)
        -h     : print this help message and exit
        [ etc. ]

你也可以设定你的脚本,它应该以这样的方式接受各种选项

如果想对python脚本传参数,需要模块:sys

参数个数:len(sys.argv)
脚本名:    sys.argv[0]
参数1:     sys.argv[1]
参数2:     sys.argv[2]
#vim test.py
import sys
print “脚本名:”,sys.argv[0]
for i in range(1,len(sys.argv)):
        print “参数”,i,sys.argv[i]

#python test.py hello world
 脚本名:test.py
 参数 1 hello
 参数 2 world

模块

每一个 Python 脚本文件都可以被当成是一个模块。模块以磁盘文件的形式存在。
当一个模块变得过大,并且驱动了太多功能的话,就应该考虑拆一些代码出来另外建一个模块。
模块里的代码可以是一段直接执行的脚本,也可以是一堆类似库函数的代码,从而可以被别的模块导入(import)调用。模块可以包含直接运行的代码块、类定义、 函数定义或这几者的组合。
后面我们会有专门的模块讲解