文章目录

  • 1.map()函数
    • 例子
  • 2.运算符问题
    • 例子
  • 3.join()函数
    • 例子
  • 4.python中range()函数用法
  • 5.内置函数int(x, base=10)
    • 例子
  • 6.print函数参数详解
    • 例子
  • 7.列表的比较
  • 8.sort()和sorted()函数总结
    • 例子
  • 9random模块

1.map()函数

转载:https://blog.csdn.net/xu_xiaoxu/article/details/83339856
python 3 的map()函数
描述:
map() 会根据提供的函数对指定序列做映射。
第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。
语法:
map() 函数语法:map(function, iterable, …)
参数:
function – 函数
iterable – 一个或多个序列
返回值:
Python 2.x 返回列表。
Python 3.x 返回迭代器
示例:
python2:

def square(x) :               # 计算平方数return x ** 2
map(square, [1,2,3,4,5])   # 计算列表各个元素的平方
>>>
[1, 4, 9, 16, 25]

python3:

def square(x) :            return x ** 2
map(square, [1,2,3,4,5])
>>>
<map at 0x1acd1c94be0>

python3可将map转换为list:

def square(x) :            # 计算平方数return x ** 2
A=list(map(square, [1,2,3,4,5]))   # 计算列表各个元素的平方
print(A)
>>>
[1, 4, 9, 16, 25]
print(map(lambda x: x ** 2, [1, 2, 3, 4, 5]))  # 使用 lambda 匿名函数
print(list(map(lambda x: x ** 2, [1, 2, 3, 4, 5])))
# 提供了两个列表,对相同位置的列表数据进行相加
print(map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10]))
print(list(map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])))
<map object at 0x000001ACD1CA7668>
[1, 4, 9, 16, 25]
<map object at 0x000001ACD1CA7710>
[3, 7, 11, 15, 19]

例子

list(map(str, [1, 2, 3]))的执行结果为['1','2','3']

2.运算符问题

例子

'''语句x = 3==3, 5执行结束后,变量x的值为3,运行结果为_________
由于等于运算符的优先级高于赋值运算符,先计算3==3,返回True
x = True,5   x的值为tuple型 (True,5)'''

3.join()函数

join()是一个字符串方法,它返回被子字符串连接的字符串。

string_name.join(iterable)
string_name:这是被连接的子字符串。

参数:The join() method takes join()方法需要可迭代的元素来一次返回它的一个成员,比如列表,元组,字符串,字典和集合
返回值: join()方法返回一个被子字符串连接的字符串
Type Error: 如果这个可迭代元素包含任何不是字符串的值,join()函数就会抛出TypeError。

下面的程序解释了join()方法是如何工作的:

list1 = ['1','2','3','4']
s = "-"
s = s.join(list1)
print(s)
>>>
1-2-3-4

例子

Python语句''.join(list('hello world!'))执行的结果是'hello world!'
' '.join(list('hello world!'))执行结果是'h e l l o   w o r l d !'

4.python中range()函数用法

转载:https://blog.csdn.net/sinat_38682860/article/details/86360471
Python2 中 range() 生成的是列表;Python3,range生成的是可迭代对象
语法:range(start, stop [,step])
参数:start 指的是计数起始值,默认是 0;
stop 指的是计数结束值,但不包括 stop ;
step 是步长,默认为 1,不可以为 0 。
range() 方法生成一段左闭右开的整数范围-包头不包尾

>>> a = range(5)
>>> a
range(0, 5)
>>> len(a)
5
>>> for x in a:
>>>     print(x,end=" ")
0 1 2 3 4

对于 range() 函数,有几个注意点
(1)它表示的是左闭右开区间;
(2)它接收的参数必须是整数,可以是负数,但不能是浮点数等其它类 型;
(3)它是不可变的序列类型,可以进行判断元素、查找元素、切片等操作,但不能修改元素;
(4)它是**可迭代对象,**却不是迭代器。

# (1)左闭右开
>>> for i in range(3, 6):
>>>     print(i,end=" ")
3 4 5# (2)参数类型
>>> for i in range(-8, -2, 2):
>>>     print(i,end=" ")
-8 -6 -4
>>> range(2.2)
----------------------------
TypeError    Traceback (most recent call last)
...
TypeError: 'float' object cannot be interpreted as an integer# (3)序列操作
>>> b = range(1,10)
>>> b[0]
1
>>> b[:-3]
range(1, 7)
>>> b[0] = 2
TypeError  Traceback (most recent call last)
...
TypeError: 'range' object does not support item assignment# (4)不是迭代器
>>> hasattr(range(3),'__iter__')
True
>>> hasattr(range(3),'__next__')
False
>>> hasattr(iter(range(3)),'__next__')
True

5.内置函数int(x, base=10)

转载:https://blog.csdn.net/caimouse/article/details/42464831
本函数实现从浮点数或数字字符串转换为整数。如果参数x不是一个数字,必须是字符串、数组bytes或bytearray类型。参数base是指字符串参数的进制,默认10就是表示使用十进制。当它是2时,表示二进制的字符串转换。当它是8时,表示是八进制的字符串转换。当它是16时,表示是十六进制的字符串转换。然而当它是0时,它表示不是0进制,而跟十进制是一样的。

print(int('20', 8))
print(int('0x20', 16))
print(int('0o73', 8))
print(int('19', 0))
16
32
59
19

例子

表达式 int('123', 16) 的值为291

6.print函数参数详解

转载:https://blog.csdn.net/phantom_dapeng/article/details/77758271
print()函数的参数如下:

print(*values, sep=' ', end='\n', file=sys.stdout, flush=False)

参数
1 *values : 表示要打印的值
表示任何多个无名参数, 各个值之间用‘,’(逗号隔开),打印出来各个值之间用空格隔开
2 sep=‘’ 表示当输入多个打印的值时,各个值之间分割方式, 默认空格,可以自定义

>>> print('a', 'b', 'c')
输出为:
a b c
(中间默认用空格隔开)

3 end=‘\n’**: 控制print中传入值输出完后结束符号,默认换行,这里可以设置为其他,如 ‘\t’, ’ ’ 等等, 可以自己定义
4 file=sys.stdout:设置输出设备,及把print中的值打印到什么地方,默认输出到准端,可以设置file= 文件储存对象,把内容存到该文件中

f = open(r'a.txt', 'w')
print('python is good', file=f)
f.close()
则把python is good保存到 a.txt 文件中

5.flush=False: 该参数主要是刷新, 默认False,不刷新,Ture时刷新,例如在上面 4 中print中设置:

f = open(r'a.txt', 'w')
print('python is good', file=f, flush=True)

正常情况下print到f中的内容先从到内存中,当文件对象关闭时才把内容输出到 a.txt 中,当flush=True时它会立即把内容刷新存到 a.txt 中

例子

Python 3.x语句 print(1, 2, 3, sep=':') 的输出结果为1:2:3

7.列表的比较

转载:https://blog.csdn.net/xiaozhimonica/article/details/86142500
两个列表的比较,是逐位比较数值大小,一旦出现“<”或“>”关系,则比较结束。
例如:

→列表:a=[1,2,3,4],b=[1,2,3,4,5],c=[1,2,3,5],d=[1,2,3,3,5]

→则有:

a<b:对于b[4]=5,a[4]不存在;
a<c:因为a[3]<c[3];
a>d:因为a[3]>d[3],比较结束。

8.sort()和sorted()函数总结

转载:https://blog.csdn.net/u014745194/article/details/73497100

sort函数是list列表中的函数,而sorted可以对list或者iterator进行排序
sort和sorted的比较
1,用sort函数对列表排序时会影响列表本身,而sorted不会

    >>> a = [1,2,1,4]>>> a.sort()>>> a[1, 1, 2, 4]>>> a = [1,2,1,4]>>> sorted(a)[1, 1, 2, 4]>>> a[1, 2, 1, 4]

2、sorted(iterable,cmp,key,reverse)

各个参数说明:iterable可以是list或者iterator;
cmp是带两个参数的比较函数;
key 是带一个参数的函数;
reverse为False或者True,表示是否反转;

(1)用cmp函数排序

    >>> list1 = [('david', 90), ('mary',90), ('sara',80),('lily',95)]# 首字母排序>>> sorted(list1,cmp = lambda x,y: cmp(x[0],y[0]))[('david', 90), ('lily', 95), ('mary', 90), ('sara', 80)]# 得分排序>>> sorted(list1,cmp = lambda x,y: cmp(x[1],y[1]))[('sara', 80), ('david', 90), ('mary', 90), ('lily', 95)]

(2)用key函数排序

    >>> list1 = [('david', 90), ('mary',90), ('sara',80),('lily',95)]# 首字母排序>>> sorted(list1,key = lambda list1: list1[0])[('david', 90), ('lily', 95), ('mary', 90), ('sara', 80)]# 得分排序>>> sorted(list1,key = lambda list1: list1[1])[('sara', 80), ('david', 90), ('mary', 90), ('lily', 95)]

(3)用reverse排序

>>> sorted(list1,reverse = True)
# 首字母反转排序
[('sara', 80), ('mary', 90), ('lily', 95), ('david', 90)]

用operator.itemgetter函数排序

>>> from operator import itemgetter
# 得分排序
>>> sorted(list1, key=itemgetter(1))
[('sara', 80), ('david', 90), ('mary', 90), ('lily', 95)]
# 首字母排序
>>> sorted(list1, key=itemgetter(0))
[('david', 90), ('lily', 95), ('mary', 90), ('sara', 80)]

1,介绍operator.itemgetter函数

import operatora = [1, 2, 3, 4, 5, 6]
b = operator.itemgetter(5)
c = b(a)
print(c)
结果为:6
operator.itemgetter()函数获取的不是值,而是定义了一个函数,通过这个函数可以获取到对应的值

多级排序

>>> sorted(list1, key=itemgetter(0,1))
[('david', 90), ('lily', 95), ('mary', 90), ('sara', 80)]

例子

已知 x = [[1,3,3], [2,3,1]],那么表达式
sorted(x, key=lambda item:item[0]+item[2]) 的值[[2,3,1],[1,3,3]]

9random模块

转载:https://blog.csdn.net/Yanghongru/article/details/104929389

import randomrandom.random()     #产生0-1之间的随机小数random.randint(a,b)        #产生[a,b]之间的随机整数
print(random.randint(1,5))random.uniform(a,b)       #产生(a,b)之间的随机小数
print(random.uniform(1,5))random.randrange(a,b,s)       #产生[a,b)之间步长为s的随机整数
print(random.randrange(1,5,2))  random.choice(a)        #返回a中个随机一个元素,a可以为str,list,tuplerandom.sample(a,b)       #返回a中随机b个元素,a只能是listrandom.shuffle(a)       #将a中元素进行重新排序,a只能是list,且shuffle()没有返回值

如果对您有帮助,麻烦点赞关注,这真的对我很重要!!!如果需要互关,请评论留言!


python基础9-常见难点相关推荐

  1. python第三方库有哪些常用的、请列举15个-python基础面试常见题

    Python是目前市面上,我个人认为是最简洁.最优雅.最有前途.最全能的编程语言,没有之一. 2.通过什么途径学习的Python? 通过自学,包括网上查看一些视频,购买一些相关专业的书籍. 3.Pyt ...

  2. Python基础课程-常见的数据结构

    字典 字典是将键(key)映射到值(value)的无序数据结构.值可以是任何值(列表,函数,字符串,任何东西).键(key)必须是不可变的,例如,数字,字符串或元组. 示例 字典:我们查找的单词是ke ...

  3. python基础实例-Python基础之字符串常见操作经典实例详解

    本文实例讲述了Python基础之字符串常见操作.分享给大家供大家参考,具体如下: 字符串基本操作 切片 # str[beg:end] # (下标从 0 开始)从下标为beg开始算起,切取到下标为 en ...

  4. Python基础学习-Python中最常见括号()、[]、{}的区别 2015-08-13 07:54 by xuxiaoxiaoxiaolu, 1138 阅读, 0 评论, 收藏, 编辑 Pytho

    Python基础学习-Python中最常见括号().[].{}的区别 2015-08-13 07:54 by xuxiaoxiaoxiaolu, 1138 阅读, 0 评论, 收藏, 编辑 Pytho ...

  5. 【机器学习基础】常见二分类损失函数、距离度量的Python实现

    本文用Python实现了常见的几种距离度量.二分类损失函数. 设和为两个向量,求它们之间的距离. 这里用Numpy实现,设和为ndarray <numpy.ndarray>,它们的shap ...

  6. Python基础day04【字典(介绍、定义与访问、操作数据、常见操作)】

    视频.源码.课件.软件.笔记:超全面Python基础入门教程[十天课程]博客笔记汇总表[黑马程序员]    目录 1. 复习反馈 判断一个方法是否有返回值 列表中的删除操作 新建day04项目 2. ...

  7. Python基础概念_14_常见术语

    常见术语 15 常见术语 15.1 简介 Python里有一些常见的专业名词.用语,我们一般统称为术语.为了更方便的学习python我们通过表格的方式列举了常用的术语和单词以及工具. 15.2 常见术 ...

  8. python100例详解-Python基础之列表常见操作经典实例详解

    本文实例讲述了Python基础之列表常见操作.分享给大家供大家参考,具体如下: Python中的列表操作 列表是Python中使用最频繁的数据类型[可以说没有之一] 一组有序项目的集合 可变的数据类型 ...

  9. python实习生基础面试题_常见的Python基本面试问题,python,基础,面试题

    常见 python 基础面试题 1,文件操作时:xreadlines和readlines的区别? readlines()是把文件的全部内容读取到内存,并解析一个list,当文件的体积很大的时候,需要占 ...

  10. Python基础概念_13_常见关键字

    常见关键字 14 常见关键字 14.1 常用关键字 Python里的关键字可通过内置的函数查看.见如下命令: >>>import keyword >>>keywor ...

最新文章

  1. php 保存表单数据,使用jquery和php自动保存表单数据
  2. python中使用flask实现人脸实时检测
  3. C\S B\S 结果,其实就是这个样子的。
  4. Android 插件化原理学习 —— Hook 机制之动态代理
  5. Python 一行代码搞定炫酷可视化,你需要了解一下 Cufflinks
  6. 【UI设计】【Photoshop系统设计大作业】【5个页面(引导页\首页*2\个人中心页\登录页)、5000字+实验报告、视频教程】
  7. java怎么学好 用好接口_Java公开课|Java的实现接口怎么用,这才是学习好Java必备的实用函数,你会吗...
  8. 【鉴轻尘】BTC的暴跌的是因为BCH的分叉,但是你知道为什么?
  9. VPP命令行:启动配置,HTTP服务,DPDK配置
  10. VS2013 工具包修复记录
  11. 什么是 Java 内存模型( JMM )
  12. 通过BSSID连接WiFi
  13. 大数据下的图片类别以及图片爬取详细的过程(一)
  14. React 优化:懒惰加载(lazy loading)
  15. HTML5之帆布(canvas)(一)
  16. ROSGazebo自定义多旋翼无人机仿真——环境搭建和模型建立
  17. Android学习之——APP番茄工作法——小结(1)
  18. Linux运维笔记-日常操作命令总结(1)
  19. FullCalendar说明文档
  20. Word学习笔记:P5-标尺和定位点要如何使用

热门文章

  1. [原]逆向iOS SDK -- “添加本地通知”的流程分析
  2. 《新浪微博用户兴趣建模系统架构》阅读笔记
  3. Oracle之触发器
  4. ceph:如何处理rados --striper上传失败的对象
  5. ram_flash驱动
  6. 【硬件】推荐软件『软硬件的基准测试工具』
  7. PaddlePaddle(8)—— 如何写好一篇高质量的精选项目
  8. C++中的命名空间(namespace)介绍
  9. 宏定义(#ifndef+#define+#endif)的作用
  10. mysql的一些查询优化,count优化,limit优化