前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python基础--Python3基础语

Python基础--Python3基础语

作者头像
py3study
发布2020-01-03 16:20:06
7200
发布2020-01-03 16:20:06
举报
文章被收录于专栏:python3python3python3

Python3 基础语法

编码

默认情况下,Python3源码文件以UTF-8编码,所有字符串都是Unicode字符串。当然也可以为源码文件指定不同的编码,例如:

# -*- coding: cp-1252 -*-

标识符

1.第一个字符必须是字母表中字母或下划线;

2.标识符的其他的部分有字母、数字和下划线组成;

3.标识符对大小写敏感。

注:在Python3中,非ASCII标识符也是允许的。

Python保留字

保留字即关键字,我们不能把它们用作任何标识符名称。Python的标准库提供了一个keyword模块,可以输出当前版本的所有关键字:

>>> import keyword
>>> keyword.kwlist
['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 
'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global',
 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise',
  'return', 'try', 'while', 'with', 'yield']

注释

Python中单行注释以#开头,举例如下:

#!/usr/bin/python3
#第一个注释
print ("Hello,Python!") #第二个注释

执行以上代码,输出结果为:

Hello,Python!

多行注释可以用多个#号:

#!/usr/bin/python3
#第一个注释
#第二个注释
print ("Hello,Python!")

执行以上代码,输出结果为:

Hello,Python!

行与缩进

Python最具特色的就是使用缩进来表示代码块,不需要使用大括号{}。

做进的空格数是可变的,但是同一个代码块的语句必须包含相同的缩进空格数。

例如:

if True:
    print("True")
else:
    print("False")

以下代码最后一行语句缩进数的空格数不一致,会导致运行错误:

if True:
    print("Answer")
    print("True")
else:
    print("Answer")
  print("False")    #缩进不一致,会导致运行错误

以上程序由于缩进不一致,执行后会出现类似以下错误:

  File "C:/Users/wuli/PycharmProjects/test.py", line 10
    print("False")    #缩进不一致,会导致运行错误
                                    ^
IndentationError: unindent does not match any outer indentation level

多行语句

Python通常是一行写完一条语句,但如果语句很长,我们可以使用反斜杠(\)来实现多行语句,例如:

total = 'item_one + \
        item_two + \
        item_three'

在[],{},或()中的多行语句,不需要使用反斜杠(\),例如:

total = ['item_one','item_two','item_three',
 'item_four','item_five']

数据类型

Python中数有四种类型:整数、长整数、浮点数和复数。

1.整数,例如1

2.长整数,比较大的整数

3.浮点数,例如1.23、3E-2

4.复数,例如1+2j、1.1+2.2j 

字符串

1.Python中单引号和双引号使用完全相同;

2.使用三引号('''或""")可以指定一个多行字符串;

3.转义符'\'

4.自然字符串,通过在字符串前加r或R。例如:r"this is a line with \n"则\n会显示,并不是换行;

5.python允许处理Unicode字符串,加前缀u或U,例如:u"this is an unicode string"

6.字符串是不可变的。

7.按字面 意义级联字符串,例如:"this" "is" "string"会被自动转换为this is string

word = '字符串'

sentence = "这是一个句子"

paragraph = """这是一个段落,

可以有多行组成"""

空行

函数之间或类的方法之间用空行分隔,表示一段新的代码的开始。类和函数入口之间也用一行空行分隔,以突出函数入口的开始。

空行与代码缩进不同,空行并不是Python语法的一部分。书写时不插入空行,Python解释器运行也不会出错。但是空行的作用在于分隔两段不同功能或含义的代码,便于日后代码维护或重构。

谨记:空行也是程序代码的一部分。

等待用户输入

执行下面的程序在按回车键后就会等待用户输入:

#!/usr/bin/python3
input("\n\n按下enter键后退出。")

以上代码中,"\n\n"在结果输出前会输出两个新的空行。一旦用户按下键时,程序将退出。

同一行显示多条语句

Python可以在同一行中使用多条语句,语句之间使用分号(;)分割,事例如下:

#!/usr/bin/python3
import sys; x = 'python';sys.stdout.write(x + '\n')

执行以上代码,结果输出为:

python

多个语句构成代码组

缩进相同的一组语句构成一个代码块,我们称之代码组。

像if、while、def和class这样的复合语句,首行以关键字开始,以冒号(:)结束,该行之后的一行或多行代码构成代码组。

我们将首行及后面的代码组称为一个子句(clause)。

例如:

if expression:
    suite
elif expression:
    suite
else:
    suite

print输出

print默认输出是换行的,如果要实现不换行需要在变量末尾加上end="":

x = 'a'
y = 'b'
#换行输出
print(x)
print(y)
print('------')
#不换行输出
print(x,end=" ")
print(y,end=" ")
print()

以上执行结果为:

a
b
------
a b

import与from...import

在Python用import或者form...import来导入相应的模块。

将整个模块(somemodule)导入,格式为:import somemodule

从某个模块中导入某个函数,格式为:from somemodule import somefunction

从某个模块中导入多个函数,格式为:from somemodule import firstfunc,secondfunc,thirdfunc

将某个模块中的全部函数导入,格式为:from somemodule import *

导入sys模块

import sys
print('================Python import mode==========================');
print ('命令行参数为:')
for i in sys.argv:
    print (i)
print ('\n python 路径为',sys.path)

输出为:

================Python import mode==========================
命令行参数为:
C:/Users/wuli/PycharmProjects/Project20170523-python3/Day1/test1.py
 python 路径为 ['C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3\\Day1', 
 'C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\python36.zip', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\DLLs', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib\\site-packages']

导入sys模块的argv,path成员

from sys import argv,path  #  导入特定的成员
 
print('================python from import===================================')
print('path:',path) # 因为已经导入path成员,所以此处引用时不需要加sys.path

输出为:

================python from import===================================
path: ['C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3\\Day1', 
'C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\python36.zip', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\DLLs', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib\\site-packages']

命令行参数

很多程序可以执行一些操作来查看一些基本信息,Python可以使用-h参数查看各参数帮助信息:

C:\Users\wuli>python3 -h
usage: python3 [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_instance)
         and comparing bytes/bytearray with str. (-bb: issue errors)
-B     : don't write .py[co] files on import; also PYTHONDONTWRITEBYTECODE=x
-c cmd : program passed in as string (terminates option list)
-d     : debug output from parser; also PYTHONDEBUG=x
-E     : ignore PYTHON* environment variables (such as PYTHONPATH)
-h     : print this help message and exit (also --help)
[etc.]

注意事项:

1. 在Windows下可以不写第一行注释:

#!/usr/bin/python3

第一行注释标的是指向 python 的路径,告诉操作系统执行这个脚本的时候,调用 /usr/bin 下的 python 解释器。

此外还有以下形式(推荐写法):

#!/usr/bin/env python3

这种用法先在 env(环境变量)设置里查找 python 的安装路径,再调用对应路径下的解释器程序完成操作。

2. 关于注释,也可以使用''' '''的格式在三引号之间书写较长的注释;

''' '''还可以用于在函数的首部对函数进行一个说明:

def example(anything):
    '''形参为任意类型的对象,
       这个示例函数会将其原样返回。
    '''
    return anything

3. help()函数

调用python的help()函数可以打印输出一个函数的文档字符串:

# 如下实例,查看 max 内置函数的参数列表和规范的文档

>>> help(max)
Help on built-in function max in module builtins:
max(...)
    max(iterable, *[, default=obj, key=func]) -> value
    max(arg1, arg2, *args, *[, key=func]) -> value
    With a single iterable argument, return its biggest item. The
    default keyword-only argument specifies an object to return if
    the provided iterable is empty.
    With two or more arguments, return the largest argument.

按下:q两个按键即退出说明文档(linux当中退出方式)

如果仅仅想得到文档字符串:

>>> print(max.__doc__) #注意,doc的前后分别是两个下划线
max(iterable, *[, default=obj, key=func]) -> value
max(arg1, arg2, *args, *[, key=func]) -> value
With a single iterable argument, return its biggest item. The
default keyword-only argument specifies an object to return if
the provided iterable is empty.
With two or more arguments, return the largest argument.
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档