【python----发轫之始】【基础知识总结】

一、自学感受

学完之后,,,感觉脑子里全是乱的,单词这么多,都要分不清什么时候该用什么,他到底属于哪一个数据类型里的函数,,,,,,

所以,我想着把笔记整理一下,方便自己和需要的人查看。

二、pycharm常用快捷键

识别菜鸟和高手的最简单的方法就是看他对于编译器玩的六不六,所以掌握基本的快捷键是必须的。

注释快捷键: CtrI + /                                             代码格式化:CtrI+ Alt + L

文件重命名: Shift + F6                                        拷贝文件路径: CtrI + Shift + C

运行程序: Shift + F10                                          调试程序: Shift + F9(debug模式)

添加补字符: Alt +鼠标左键                                   光标在行开头: CtrI + [

光标在行结尾:CtrI+ ]                                            选中当前行:Ctrl + Shift + [

取消选中: Ctrl + Shift + ]                                     选择剪贴板内容插入: CtrI + Shift + Insert

撤销: Ctrl+ Z                                                        恢复: Ctrl + Shift + Z

复制当前行: CtrI + D                                            删除当前行: Ctrl + Y

移动当前行: Shift + Alt +↑↓                                 代码补全: Ctrl+ Alt +空格

单步执行: F8

三、字符串常见操作

命名两个str类型的str1和str2,temp。

1str1.find(str2,start = 0,end = len(str1) )  

用于查找str2在str1中的索引值,如果没有,返回-1。(从左往右)

rfind用法一样,只不过是从右往左查找。

index,和   find()差不多,没找到会报异常。

rindex,和    rfind()差不多,没找到会报异常。

2.str1.count(str2,start = 0,end = len(str1)) 

统计 在str1的start 到  end 中str2出现的次数。

3.str1.replace(temp,str2,count)

把在str1中的 字符串 temp替换为 str2   count 次。

4.str1.capitalize()

字符串的第一个字母大写。

5.str1.title()

字符串中的每一个单词的首字母大写。

6.str1.lower()

把字符串中的字母全部变为小写。

7.str1.upper()

把字符串中的字母全部变为大写。

8.str1.strip()

删除字符串两边空白字符。

rstrip()     删除字符串右边空白字符。

lstrip()     删除字符串左边空白字符。

9.str1.splitlines()

str1中如果包含 ('\r', '\r\n', \n') ,将其分开储存在列表中。

10.str3 = str1.join(str2)

将str2的每一个字符用字符串str1连接起来。

11.str1.split(ch)

将str1以字符串为划分点分成几部分储存到列表中。

四、运算符优先级

序号 运算符
1 **
2 ~    +     -(一元加减号)
3 *     /     %     //
4 +      -
5 >>    <<
6 &
7 ^       |
8 <=    <    >   >   =
9 ==   !=
10 =     %=    /=     //=    -= +=     *=   **=
11 is    is not
12 in    not in
13 not    or    and

五、列表常用函数

1.list2 =  list1[a:b]

 

将列表中a到b-1的元素放入list2 列表中。

2.list1.revers()

反转列表。

3.list1.append(list2)

将list2整个列表追加到list1中。

4.list1.extend(list2)

将list2列表中的元素追加到list1中。

5.list1.insert(a,chr)

将chr元素插入到list1中的第a个位置中。

6.list1.remove(chr)

将list1中的chr删除。

7.list1.pop(a)

按照索引值将list中的值删除。

8.list1[a,b] = []

将a到b-1元素删除。

9.cnt = list1.count(chr)

统计chr元素在list1中出现的次数。

10 list2 = list1.copy()

复制list1中的元素到list2中,(不是指向同一块内存)

list2 = list1  (这个就会指向同一块内存)

10.list1.sort()

升序排序

11.list1.sort(reverse = True)

降序排序

12.sorted(list1)

对列表进行排序,生成新列表,不修改原列表。元组也适用。

13.max(list1)      min(list1)

返回列表中的最大最小值

14.sum(list1)

返回数字列表数的总和。

 

六、字典常用函数

1.dict1 = dict(keys = values,.........)

 

字典的创建,也可以用花括号直接创建。

2.dict1 = dict.fromkeys([keys,........] ,     这里填默认值   )

初始化字典

3.dict1.get(chr,ch)

在字典中获取chr对应的值,如果没有,默认返回指定的ch.

也可以用dict1[chr] 的方法获取,没有返回指定值的东西。

4.字典的遍历

for key in employee:
    v = employee[key]
    print(v)

for k,v in employee.items():
    print(k,v)

5.字典的更新(有则更新,无则新增)

dict1[chr] = v          单个更新

dict1.update(keys = value,..........)    多个更新

6.字典的删除

dict1.pop(chr)       删除指定的key 和 value

dict1.popitem()     删除最后一个key 和 value

7.dict1.clear()

清空字典

8。获取字典的视图

dict1,keys()   代表获取所有的键

dict1.values()   代表获取所有的值

dict1.items()      代表获取所有的键值对

以其中的一个为例:

ks = dict1,keys() ,ks会随着dict1中内容的变化而变化,不是固定不变的。 

9.dict1.setdefault(key,value)

默认初始化,若已经存在key了,就会忽略这个语句,无就添加。

10.字符串格式化

# 老版本的字符串格式化
emp_str = "姓名:%(name)s,评级:%(grade)s,入职时间:%(hiredate)s" %emp1

# 新版本的字符串格式化 emp_str1 = "姓名:{name},评级:{grade},入职时间:{hiredate}".format_map(emp1)

七、元组注意事项

如果元组只有一个元素时,必须在这个元素后增加逗号说明这是一个元组。
元组只能访问,不能改变其 值,除非包含了列表。

 

八、集合常用函数

 集合是没有value值的字典。

创建时和字典差不多,只是创建空集合时要用set()。

注意:集合不支持按照索引提取数据  用in 判断是否在其中,for循环遍历集合。

集合的一些函数:

1.求交集

c1 = set1.intersection(set2)    获取交集,新建集合。

set1.intersection_update(set2)      更新原有集合。

2.求并集

c1 = set1.union(set2)      获取并集,去重,新建集合。

3.求差集

c1 = set1,difference(set2)    获取set1在set2中不存在的部分,新建集合。

c1 = set1.symmetric_difference(set2)    获取双向差集,新建集合。

差集也有update

set1.symmetric_difference_update(set2)    获取双向差集。更新set1.       

4.set1 == set2 

判断两集合中的元素是否都相同。

5.set1.issubset(set2)

判断set1是否是set2的子集。

6.set1.issuperset(set2)

判断set1是否是set2的父集。

7.set1.isdisjoint(set2)

判断set1是否和set2无重复元素。

8.set1.add(ch)

更新数据,一次只能更新一个。

9.set1.update(ch1,ch2)

更新数据,一次能更新多个。

10.set1.remove(ch)

删除数据,如果没有ch,会报错。

11.set1.discard(ch)

删除数据,如果没有ch,不会报错,直接忽略。 

九、生成式

生成式很简单,说一下语法就行生成式语法: [被追加的数据 循环语句 循环或者判断语句]|{}

 

十、常用高阶函数

1.lambda 函数的用法

def f(n):
    return n % 2 == 0

print(f(2))

print(bool(lambda n: n % 2 == 0))

输出后都为 True 。

说明这两个函数是等价的,后者更加简洁,也是lambda函数的好处。

2.filter(function, iterable)

function -- 判断函数。
iterable -- 可迭代对象。

filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回一个迭代器对象,如果要转换为列表,可以使用 list() 来转换。

我们用range数组和lambda函数进行讲解。

#输出0~19 个数中的奇数
print(list(filter(lambda n: n % 2, range(0, 20))))
#得到 [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]

 

3.reduce(function, iterable[, initializer])

用之前要引入函数

from functools import reduce

function -- 函数,有两个参数
iterable -- 可迭代对象
initializer -- 可选,初始参数

from functools import reduce

print(reduce(lambda x, y: x * y, range(1, 21)))
#得到 20!

 

函数将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给 reduce 中的函数 function(有两个参数)先对集合中的第 1、2 个元素进行操作,得到的结果再与第三个数据用 function 函数运算,最后得到一个结果。

如果只是求和,用内置的sum(list1) 也可以得到答案。

4.map(function, iterable, ...)

function -- 函数

iterable -- 一个或多个序列

#计算各个数的立方

print(list(map(lambda n: n**3, range(1, 11))))
#输出[1, 8, 27, 64, 125, 216, 343, 512, 729, 1000]

 

 

如果有哪里写错了,希望大佬指点一下,蟹蟹!!

posted @ 2020-05-21 16:46  Vincent&  阅读(282)  评论(0编辑  收藏  举报