这里为大家推荐一些不错的学习python基础的网站
Python是一种计算机程序设计语言。你可能已经听说过很多种流行的编程语言,比如非常难学的C语言,非常流行的Java语言,适合初学者的Basic语言,适合网页编程的JavaScript语言等等。
那Python是一种什么语言?
首先,我们普及一下编程语言的基础知识。用任何编程语言来开发程序,都是为了让计算机干活,比如下载一个MP3,编写一个文档等等,而计算机干活的CPU只认识机器指令,所以,尽管不同的编程语言差异极大,最后都得“翻译”成CPU可以执行的机器指令。而不同的编程语言,干同一个活,编写的代码量,差距也很大。
比如,完成同一个任务,C语言要写1000行代码,Java只需要写100行,而Python可能只要20行。
所以Python是一种相当高级的语言。
你也许会问,代码少还不好?代码少的代价是运行速度慢,C程序运行1秒钟,Java程序可能需要2秒,而Python程序可能就需要10秒。
那是不是越低级的程序越难学,越高级的程序越简单?表面上来说,是的,但是,在非常高的抽象计算中,高级的Python程序设计也是非常难学的,所以,高级程序语言不等于简单。
但是,对于初学者和完成普通任务,Python语言是非常简单易用的。连Google都在大规模使用Python,你就不用担心学了会没用。
用Python可以做什么?可以做日常任务,比如自动备份你的MP3;可以做网站,很多著名的网站包括YouTube就是Python写的;可以做网络游戏的后台,很多在线游戏的后台都是Python开发的。总之就是能干很多很多事啦。
Python当然也有不能干的事情,比如写操作系统,这个只能用C语言写;写手机应用,只能用Swift/Objective-C(针对iPhone)和Java(针对Android);写3D游戏,最好用C或C++。
如果你是小白用户,满足以下条件:
会使用电脑,但从来没写过程序;
还记得初中数学学的方程式和一点点代数知识;
想从编程小白变成专业的软件架构师;
每天能抽出半个小时学习。
不要再犹豫了,这个教程就是为你准备的!
准备好了吗?这是小白的Python新手教程,具有如下特点:
中文,免费,零起点,完整示例,基于最新的Python 3版本。
https://www.liaoxuefeng.com/wiki/1016959663602400
by:咕咕咕 6.18
1.python学习:
什么是python?
类似java 面向对象编程语言
python可以干什么?
java可以干的 他都可以做,语法比java简单 上手简单
python怎么用?
安装python 勾选 add to path 自动配置环境变量
python 常用方法:
id() :查看对象的id值 对象一旦被创建是无法更改id值的!
语法:a = 5
id(a)
print() :输出语句 (python中建议一行代码不超过80个字符 一条语句使用 ‘\' 分开到下一行)
语法:print(123,'gubin',"古斌")
type() : 查看对象的类型
len() : 查看对象的长度 length
max() :查看最大元素 【数组/多个数字】
min() :查看最小元素 【数组/多个数字】
index() : 查看指定元素出现的第一次索引位置 举例 列表.index("列表中的元素")
count() : 查看元素出现的次数 举例 列表.count("列表中的元素")
# 设置要替换的字符 print("--" * 40) # 打印原列表 print("打印原列表", students) name = "gb" # 1.查询ww的索引位置 index = students.index("ww") # 2.开始替换 students[index] = name # 打印新的列表 print("替换之后的列表", students) # 打印位置 print("新元素所在的位置", index + 1) # 切片 0 - index print("切片 0-index+1", students[0:index + 1]) # 向列表中末尾添加一个 qe 钱二并执行打印 students.append("qe") print("向列表中末尾添加一个 qe 钱二并执行打印", students) # 删除索引为0的元素并执行打印 del students[0] print("删除索引为0的元素并执行打印", students) # 添加 'w2' 吴二 索引为1的位置 并执行打印 students.insert(1, 'w2') print("添加所以为1的位置 并执行打印", students) # 索引2删除并返回被删除的元素 print("索引2删除并返回被删除的元素", students.pop(2)) # 删除lb 并打印 students.remove("lb") print("删除lb 并打印", students) # 进行排序 print(number) number.sort(reverse=True) print(number) # 清空列表 打印 # students.clear() print(students) # 遍历序列 numb = 0 while numb < len(students): print(students[numb]) numb += 1 print("*" * 20) # for 循环遍历 for lists in students: print(lists)
特点说明:
1): Python是一个动态语言 他不像java需要有String int boolean 这些关键字 他可以对一个变量
随意赋值 a = 1 a = 'zs' a = False
2): Python中的命名规则 : 只能包含 字母 数字 下划线 并且不能数字开头,Python有两种命名规则
1下划线命名法:所有的字母小写 单词之间使用 下划线区分
2.帕斯卡命名法:首字母大写,每个单词开头字母大写 其他字字母小写
3): Python中的类型:
Python中虽然不需要类型(String,int...)规定但是还是有自己的一套格式
# 在Python数值分成了三种:整数、浮点数(小数)、复数
***在python所有的整数都是int类型 没有长度要求 可以用 _ 作为分隔符
a = 999999999999999999999
a = 9999999999_999999_99999
正常输出,不影响
***在Python中 数字 加 字符串 会报错 ;10进制数字不能以0开头复制
***在Python中 二进制0b开头 八进制0o开头 十六进制0x开头
***在Python中所有浮点数都是 float类型(对浮点数进行运算时,可能会得到一个不精确的结果)
*** Python中的注释
# 单行注释
''' 多行注释 '''
4):Python中的格式化字符串
字符串的占位符 使用 %
%s 代表字符串占位符
%3.5s 代表3至5个字符串
%f 代表浮点站位符号
%.2f 代表接受数字后的两位 并四舍五入 12.123 打印12.12 ;12.456 打印 12.46
%d 代表接受整数
举例:
a = "hello %s" % "zs" print(a) : hello zs a = "hello %s 你好 %s" % ("zs","ls") print(a) : hello zs 你好 ls a = "show : %3.5s" % "gubinlalala" print(a) : show: gubin a = "show float: %f" % 123.123 print(a) : show float: 123.123 a = "show float: %.2f" % 123.456 print(a) : show float: 123.46 (会进行四舍五入 并显示小数后的2位) a = "show number: %d" % 123456.33 print(a) : show number: 123456 (会显示整数 不会进行四舍五入)
"字符串与数字的拼接"
将数字变量"添加到字符串中显示"
举例:
a = 10;
print(f'a的值是{a}')
: a的值是10
5)字符进行乘法运算 会将字符串 * 被乘数 遍 (可以使用制表符)
举例
a = "show"
print(a * 5 )
:showshowshowshowshow
a = "show\t"
print(a * 5)
:show show show show show
6)Python中的 True 与 False 与 None
Python中 True 等于 1 False 等于 0
None代表空值
7) Python中的类型 使用(type() 方法查看)
a = 123 :<class 'int'>
b = 123.1 :<class 'float'>
c = True :<class 'bool'>
d = "123" :<class 'str'>
e = None :<class 'NoneType'>
f = [] :<class 'list'> 列表
g = {} :<class 'dict'> 元组
h = () :<class 'tuple'>字典
i = {} :<class 'set'> 集合
8)# 算术运算符
+ 加法运算符(如果是两个字符串之间进行加法运算,则会进行拼串操作)
- 减法运算符
* 乘法运算符(如果将字符串和数字相乘,则会对字符串进行复制操作,将字符串重复指定次数)
/ 除法运算符,运算时结果总会返回一个浮点类型
// 整除,只会保留计算后的整数位,总会返回一个整型
** 幂运算,求一个值的几次幂
% 取模,求两个数相除的余数
9)# 赋值运算符
= 可以将等号右侧的值赋值给等号左侧的变量
+= a += 5 相当于 a = a + 5
-= a -= 5 相当于 a = a - 5
*= a *= 5 相当于 a = a * 5
**= a **= 5 相当于 a = a ** 5
/= a /= 5 相当于 a = a / 5
//= a //= 5 相当于 a = a // 5
%= a %= 5 相当于 a = a % 5
10) # 关系运算符
关系运算符用来比较两个值之间的关系,总会返回一个布尔值
如果关系成立,返回True,否则返回False
> 比较左侧值是否大于右侧值
>= 比较左侧的值是否大于或等于右侧的值
< 比较左侧值是否小于右侧值
<= 比较左侧的值是否小于或等于右侧的值
== 比较两个对象的值是否相等
!= 比较两个对象的值是否不相等
(相等和不等比较的是对象的值,而不是id)
is 比较两个对象是否是同一个对象,比较的是对象的id
is not 比较两个对象是否不是同一个对象,比较的是对象的id
Python中支持连续比较 比如 result a>b>c
11) 三元用算符
语句1 if 条件 else 语句2
a = True
print("真") if a else print("假") #输出真
12) 流程控制:
if判断
if 条件1:
语句1
elif:
语句2
else:
语句3
input()输入: username = input("请输入用名") if username == "zs": print("输入正确") else: print("输入错误") while i = 0 while i < 10: i += 1 print("i=", i) else: print("else代码块")
13) 容器:
第一个 列表 (java中数组)
创建:
arr = []
它可以存取任何数据,下标从0开始,有序,print(arr) 直接打印出该 列表所有元素 类似于 java的toString!不可以下标越界!
stus = ['孙悟空','猪八戒','沙和尚','唐僧','蜘蛛精','白骨精']
stus[2] 打印沙和尚
stus[-1] 打印白骨精 (也就是说 从后往前获取 就是负数获取 下标从-1开始,正着获取下标就是从0开始)
切片:
切片指从现有列表中,获取一个子列表
语法:列表[起始:结束:步长] # 步长不能是0,但是可以是负数
stus = ['孙悟空','猪八戒','沙和尚','唐僧','蜘蛛精','白骨精']
print(stus[0:5:3]) 也就是:['孙悟空','唐僧']
从0索引开始 到5索引结束 但是不包括5索引 每隔三个截取一个
print(stus[1:]) 如果省略结束位置,则会一直截取到最后
print(stus[:3]) 如果省略起始位置,则会从第一个元素开始截取
print(stus[:]) 如果起始位置和结束位置全部省略,则相当于创建了一个列表的副本
通用操作: + 和 *
+可以将两个列表拼接为一个列表
my_list = [1,2,3] + [4,5,6]
* 可以将列表重复指定的次数
my_list = [1,2,3] * 5
判断该元素是否存在于该 列表中 :使用 语法: '元素' [not] in 列表
# 创建一个列表
stus = ['孙悟空','猪八戒','沙和尚','唐僧','蜘蛛精','白骨精','沙和尚','沙和尚']
print('孙悟空' in stus) :True
print('孙悟空' not in stus) :False
#创建列表
numbers = [1,5,6,9,10,66,5]
print(max(numbers)) 打印66
print(min(numbers)) 打印1
元组
元组跟列表是一样的 它出现的目的就是 元组中的数据不可以被改变
语法 :my——tuple = ()
元组是不可变对象;如果元组不是空的括号可以省略,如果必须要用括号 数据后面必须有 ,
删除不可以删除单一的元素 只能将此元组删除掉
# 定义元组 my_tuple = () print("这是一个空的元组", my_tuple) my_tuple = (2, 1,) print("如果最后不带, 会报语法错误,但是不影响数据", my_tuple) my_tuple = 1, 2, 3, 6, 5 print("不使用括号", my_tuple) 解包:在对一个元组进行解包时,变量的数量必须和元组中的元素的数量一致 # 元组中的解包 将元组中的数据 赋值给变量 (将元组看成数据) ps: 解包不只是元组中使用 my_tuple = "zs", "ls", "ww", "zl" print("未解包:", my_tuple) # 执行解包 将数据依次赋值给 abcd 四个变量 a, b, c, d = my_tuple # 打印这些变量的值 print(a, b, c, d) :zs ls ww zl # 普通的解包 将 a b 的值交换 a = 100 b = 200 print("未解包:","a:",a,"b",b):未解包: a: 100 b 200 a,b = b,a :解包:a=200,b=100 print(f"解包:a={a},b={b}")
总结
#1.在对一个元组进行解包时,变量的数量必须和元组中的元素的数量一致 #2 不过可以使用 * 来接受剩下的值:(一条语句中不允许出现多个 * 只能是最后一个字符可以带有 * ) # 定义一个 元组 my_tuple = 10, 20, 30, 40 # 开始解包 a, b, *c = my_tuple print("解包后的数据:",a,b,c) :解包后的数据: 10 20 [30, 40] 可变对象: # == != is is not # == != 比较的是对象的值是否相等 # is is not 比较的是对象的id是否相等(比较两个对象是否是同一个对象) a = [1,2,3] b = [1,2,3] print(a,b) print(id(a),id(b)) print(a == b) # a和b的值相等,使用==会返回True print(a is b) # a和b不是同一个对象,内存地址不同,使用is会返回False 字典: 这个字典呢,跟json非常的相似,字典也是用来存数据的 ,跟json的格式一模一样 语法:a = {} 创建一个空的字典 {key:value,key:value...} 字典的值(value)是任意的对象 ,键是不可重复的, 如果出现重复的后边的会替换到前边的 student = {"name":'zs',"age":18,"sex":'男'} 获取字典中的值 print(student["name"]) # 打印zs print(student("ss")) # 如果键不存在 TypeError: 'dict' object is not callable 使用dict()函数创建字典 # 每个参数都是一个键值对参数名就是键,参数名就是值(这种方式创建的字典,key都是字符串) dicts = dict(name="zs", age=8) print(dicts) 打印 {'name': 'zs', 'age': 8} # 也可以将一个包含有双值子序列的序列转换为字典 如果序列是单数 那么将报错 dicts = dict([(1, 2), (3, 5)]) print(dicts) 打印 {1: 2, 3: 5} # len() 获取字典中键值对的个数 # print(len(dicts)) :2 # in 检查字典中是否包含指定的键 # not in 检查字典中是否不包含指定的键 # 通过[]来获取值时,如果键不存在,会抛出异常 KeyError # get(key[, default]) 该方法用来根据键来获取字典中的值 dicts.get("name") 打印zs # 如果获取的键在字典中不存在,会返回None # 也可以指定一个默认值,来作为第二个参数,这样获取不到值时将会返回默认值 # print(d.get('name')) # print(d.get('hello','默认值')) student = { "name": 'zs', "age": 18, "sex": '男' } print(student.get("name")) # 返回zs print(student.get("ss", "不存在")) # 第二个参数设置默认值 如果不存在就返回默认值 # 修改字典 # d[key] = value 如果key存在则覆盖,不存在则添加 student['name'] = 'sunwukong' # 修改字典的key-value student['address'] = '花果山' # 向字典中添加key-value print(student) # {'name': 'sunwukong', 'age': 18, 'sex': '男', 'address': '花果山'} # setdefault(key[, default]) 可以用来向字典中添加key-value # 如果key已经存在于字典中,则返回key的值,不会对字典做任何操作 # 如果key不存在,则向字典中添加这个key,并设置value result = student.setdefault("name", "猪八戒") print(result) # 返回原有的孙悟空 result = student.setdefault("isPerson", "No") print(result) # 设置 并返回值 print(student) # update([other]) # 将其他的字典中的key-value添加到当前字典中 # 如果有重复的key,则后边的会替换到当前的 d = {'a': 1, 'b': 2, 'c': 3} # {'a': 7, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6} d2 = {'d': 4, 'e': 5, 'f': 6, 'a': 7} d.update(d2) print(d) # 删除 删除键 Value 将会同样的删除 d = {'a': 1, 'b': 2, 'c': 3} # {'b':2,'c':3} del d["a"] print(d) # popitem() # 随机删除字典中的一个键值对,一般都会删除最后一个键值对 # 删除之后,它会将删除的key-value作为返回值返回 # 返回的是一个元组,元组中有两个元素,第一个元素是删除的key,第二个是删除的value # 当使用popitem()删除一个空字典时,会抛出异常 KeyError: 'popitem(): dictionary is empty' result = d.popitem() print(result) # clear()用来清空字典 d.clear() # pop(key[, default]) # 根据key删除字典中的key-value # 会将被删除的value返回! # 如果删除不存在的key,会抛出异常 # 如果指定了默认值,再删除不存在的key时,不会报错,而是直接返回默认值 result = d.pop('d', "bucuoza") result = d.pop('z', '这是默认值') # copy() # 该方法用于对字典进行浅复制 # 复制以后的对象,和原对象是独立,修改一个不会影响另一个 # 注意,浅复制会简单复制对象内部的值,如果值也是一个可变对象,这个可变对象不会被复制 print("-" * 20) a = {'a': 1, 'b': 2, 'c': 3} b = a.copy() print(a) a = {"name":1} print(a) print(b) # 创建集合 sets = {10, 20, 30, 40} # 遍历集合 print(sets) # 打印{40, 10, 20, 30} 因为是Set集合 没有顺序 # 创建空集合 set2 = () print(set2) # 只会打印一个 () # 使用Set() 创建集合 setlist = set('hello') # 打印 {'l', 'o', 'h', 'e'} print(setlist) # 判断 sets = {10, 20, 30, 40} print(10 in sets) # 打印True print(10 not in sets) # 打印False # 查看len print(len(sets)) # 打印4 # 使用Update 1将一个集合中的元素添加到当前集合中2. update()可以传递序列或字典作为参数,字典只会使用键 set01 = {10, 20, 30, 40} set02 = set('hello') set01.update(set02) # 将set02集合中的值存到 set01中 print(set01) # {40, 10, 'o', 20, 'l', 'e', 'h', 30} set01.update([(1, 2, 3)]) print(set01) # {40, 10, (1, 2, 3), 'o', 20, 'l', 'e', 'h', 30} # pop() 随机删除并返回 print(set01.pop()) # remove()删除集合中的指定元素 # set01.remove('o') print(set01) # clear 清空集合 # set01.clear() # print(set01) # copy oo = set01.copy() print(oo) print(type(set01)) # 集合的运算 a = {1, 2, 3} b = {3, 4, 5, 6, 7} # 交集运算 (将相同的数据拿出来) print(a & b) # {3} # 并集运算 (所有数据和到一起 去重) print(a | b) # {1,2,3,4,5,6,7} # 差集 (a中有b中没有的数据) print(a - b) # {1,2} # 异或集 (两个集合中 不重复的数据) print(a ^ b) # {1,2,4,5,6,7} # 重新定义集合 a = {1, 2, 3, 4} b = {1, 2, 3, 4, 5, 6} # 子集 与 超集 如果 a中的数据在b中全部出现 那么就可以说 : a 是 b 的子集 b是a的超集 print(a <= b) # 真子集 与 真超集 如果 a中的数据 在b中全部存在并且b中还有a中没有的数据 那么 a就是b的真子集 b就是a的真超集 print(a < b)
练习的小Demo
01.打印: 你好 xxx 啦啦啦! 使用四种方式:
#定义变量 name = "zs" #定义打印语句 print("你好"+name+"啦啦啦") :你好zs啦啦啦 print(f"你好{name}啦啦啦") :你好zs啦啦啦 print("你好",name,"啦啦啦") :你好 zs 啦啦啦 (打印语句的时候会有空格) print("你好%s啦啦啦" % name) :你好zs啦啦啦
02. 字符的加密
from urllib.parse import quote, unquote name = "古斌" # 编码 utf8_name = quote(name) # utf-8 print(utf8_name) # %E5%8F%A4%E6%96%8C 长度是 9 gbk_name = quote(name, encoding="gbk") print(gbk_name) # %B9%C5%B1%F3 长度是 6 # 解码 print(unquote(utf8_name)) print(unquote(gbk_name, encoding="gbk"))
判断三个数那个最大
a = 9 b = 5 c = 36 max = a if a > b else b max = c if c > max else max print(max)
1为男 0为女 其他为人妖 (因为input() 接受的数据都是字符串 所以需要强转)
sex = int(input("请输入你的性别:")) if sex == 0 : print("你是个小姐姐") elif sex == 1: print("你是小哥哥") else: print("你是人妖")
员工信息管理
# 创建死循环 循环数据 # 初始化员工 emps = ["张三,20,java"] while True: # 初始化公告栏 print("-" * 20, "欢迎来到员工管理系统", "-" * 20) # 打印语句 print(f"---》》 初始化员工状态成功..当前员工个数为{len(emps)}人") # 执行选择项 print("请选择您的操作:") print("1:查看员工\n2.添加员工\n3.删除员工\n4.退出系统") # 创建输入 select = int(input("请选择编号:")) # 判断用户的输入 if select == 1: print(f"当前的员工有:{emps},共 {len(emps)} 人!") elif select == 2: # 获取用户输入 emp_info = input("请依次输入员工姓名,年龄,专业:并且用逗号分开:") # 使用append添加数据 emps.append(emp_info) # 打印数据 print(emps) elif select == 3: boo = True while boo: empNumber = int(input("请输入要删除的员工的序号:")) if empNumber is None: # 如果需要为空 print("输入不能为空") elif empNumber < 0 or empNumber > len(emps): # 如果下标越界 print("序号不合法") else: del emps[empNumber] # 执行删除 if len(emps) > 0: if_del = input(f"删除成功现在有{len(emps)}位员工!是否继续删除?Y/N") if if_del == 'Y': boo else: print("程序退出") boo = False break else: print("员工个数为0。。程序退出..") break elif select == 4: print("欢迎下次使用") break
06# 键盘输入判断是否存在
# 创建键盘输入 query_name = input("请输入你要查询人的姓名:") # 判断用户输入的 name 是否存在于列表中 if query_name in students: # 如果存在 print(f"{query_name},存在于【students】列表中,他存在于{students.index(query_name)+1}的位置") else: # 不存在 print(f"{query_name}不存在于列表中") print("*" * 40)
把上述内容理解了并手工打出来基础上就可以入门了,手上要买本书啊,比较需要一些理论知识的。
简明Python基础
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]