专栏首页python3Python基础--Python3基础语

Python基础--Python3基础语

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.

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python每天五分钟-函数

    Python内置了很多函数,可以直接进行调用,要调用函数需要知道函数名和参数,可以通过官方文档进行查阅。

    用户2475223
  • 答粉丝问|用冒泡对txt文本里的英文字串排序

    根据现有条件,笔者作本文回答粉丝疑问,并更改条件如下:如何用python实现将一个储存了很多英文字符串的txt文档重新以首字母的顺序排列好。

    算法与编程之美
  • 你真的会调试 Linux 内核故障吗,看完这一篇后你会茅塞顿开的!

    内核环形缓冲区是物理内存的一部分,用于保存内核的日志消息。它具有固定的大小,这意味着一旦缓冲区已满,较旧的日志记录将被覆盖。

    iMike
  • Mysql误删,恢复数据,binlog闪回,宝塔面板

    MySQL闪回(flashback)利用binlog直接进行回滚,能快速恢复且不用停机。

    宣言言言
  • Python启动WSGI,make_server报错

    今天写了一个简单的python web server,启动后访问浏览器报了一个错误,如下:

    用户2475223
  • python|50行python代码拯救“懒癌”

    刚刚开始学python的时候,老师就说“现代技术的发展最终目的就是为了方便”,说白了,就是大家都“懒”, 懒得什么事情都亲力亲为,如果有工具能帮助我们做事,岂不...

    算法与编程之美
  • Netflix开源Metaflow Python库

    Netflix的数据科学团队已将其Metaflow Python库开源,该库是“以人为中心”的机器学习基础架构的关键部分,用于构建和部署数据科学工作流。

    AiTechYun
  • Python每天五分钟-条件控制

    注意:input()函数返回值是字符串类型的,需要使用int()函数转换成整数,int()函数如果参数类型为其他类型会报错,导致程序终止。浮点数可以用float...

    用户2475223
  • 如何用Python在笔记本电脑上分析100GB数据(上)

    本文中蓝色字体为外部链接,部分外部链接无法从文章中直接跳转,请点击【阅读原文】以访问。

    AiTechYun
  • 我是如何培养新人的:关于如何制作一个python库?

    我喜欢提出问题给新人去解决,而不会直接把答案告诉他。最近在工作中完成了一些文本分类的算法,涉及到最后的工程化问题,于是我布置了个作业,要求是把代码整理成pyth...

    mixlab

扫码关注云+社区

领取腾讯云代金券