Python程序设计——列表

news2024/9/28 13:28:22

一、引言

关键点:一个列表可以存储任意大小的数据集合。

        程序一般都需要存储大量的数值。假设,举个例子,需要读取100个数字,计算出它们的平均值,然后找出多少个数字是高于这个平均值的。程序首先读取100个数字并计算它们的平均值,然后把每个数字和平均值进行比较来确定它是否超过了平均值。为了完成这个任务,这些数字都必须存储在变量内。为了这样做,你必须创建100个变量并且重复编写几乎同样的一段代码100次。显然,编写一个这样的程序是不切实际的。因此,这个问题该怎么,解决?

        我们需要一个高效、条理的方式。Python 提供了一种被称为列表的数据类型,它可以存储一个有序的元素集合。

二、列表基础

关键点:列表是一个用list类定义的序列,它包括了创建、操作和处理列表的方法。列表中的元素可以通过下标来访问。

2.1 创建列表

list类定义了列表。为了创建一个列表,可以使用list的构造方法,如下所示:

list1 = list() # Create an empty list
list2 = list([2,3,4]) # Create a list with elements 2,3,4
list3 = list(["red", "green", "blue"]) # Create a Tist with strings
list4 = list(range(3, 6)) # Create a list with elements 3, 4,5
list5 = list("abcd") # Create a list with characters a,b,C,d

也可以使用下面这个更简单一些的语法来创建列表:

listl = [] # Same as 1ist()
list2 = [2,3,4] # Same as list([2,3,4])
list3 = ["red", "green"] # Same as list(["red", "green"])

列表中的元素用逗号分隔并且由一对中括号([ ])括住。

注意:一个列表既可以包含同样类型的元素也可以包括不同类型的元素。例如,下面的列表也是可以的:

list4 =[2, "three", 4]

2.2 列表是一种序列类型

        Python中的字符串和列表都是序列类型。一个字符串是一个字符序列,而一个列表则是任何元素的序列。序列的常用操作被总结在表10-1 中。对字符串的序列操作同样适用于列表。

2.3 列表使用的函数

        一些Python内嵌函数可以和列表一起使用。可以使用len函数返回列表的元素个数,使用max/min函数返回列表中的最大值元素和最小值元素,而sum函数返回列表中所有元素之和。还可以使用random模块中的shuffle函数随意排列列表中的元素。下面是一些例子:

>>> list1 = [2, 3,4,1,32]
>>> len(list1)
5
>>> max(list1)
32
>>> min(list1)
1
>>> sum(list1)
42
>>> import random
>>> random.shuffle(list1) # Shuffle the elements in 1ist1
>>> list1
[4,1,2,32,3]
>>>

2.4 下标运算符[ ]

一个列表中的元素都可以使用下面的语法通过下标操作符访问:

myList[index]

列表下标是基于0的,也就是说,下标的范围从0到len(myList)-1,如图10-1 中阐述:myList[index]可以像变量一样使用,所以它也被称为下标变量。例如:下面的代码将myList[0]与myList[1]中的值相加并赋给myList[2]。

myList[2] = myList[0] + myList[1]

下面的循环将0赋值给myList[0]、将1赋值给myList[1]、...、将9赋值给myList[9]:

警告:越界访问列表是一个常见的程序设计错误,它会导致一个运行时的“IndexError” 。为了避免这种错误,要确保没有使用超出len(myList)-1的下标。

2.5 列表截取[start:end]

        下标运算符允许选择一个指定下标位置上的元素。而截取操作使用语法list[start:end] 返回列表的一个片段。这个片段是下标从start到end-1的元素构成的一个子列表。下面是一些例子:

>>> list1=[2,3,5,7,9,1]
>>> list1[2 : 4]
[5, 7]
>>>

起始下标和结尾下标是可以省略的。在这种情况下,起始下标为0而结尾下标是最后一个下标。

注意:如果start>=end,那么list[start:end] 将返回一个空表。如果end指定了一个超出列表结尾的位置,那么Python 会将使用列表长度替代end。

2.6  +、*和in/not in运算符

        可以使用连接运算符(+)来组合两个列表,使用复制运算符(*)复制列表中的元素。下面是一些例子:

>>> list1 = [2,3]
>>> 1ist2
[1,9]
>>> list3 = 1ist1 + 1ist2
>>> 1ist3
[2, 3,1,9]
>>>
>>> list4 = 3 * list1
>>> list4
[2, 3,2,3,2,3]
>>>

        通过连接list1 和list2就会得到一个新列表(第3行)。第7行将list1复制三次以创建一个新列表。注意: 3*list1和list1*3相同。

        可以使用in或者not in运算符来判断一个元素是否在列表中。例如:

>>> list1 = [2,3,5,2,33, 21]
>>> 2 in listl
True
>>> 2 not in list1
False
>>>

2.7 使用for循环遍历元素

        Python列表中的元素是可迭代的。Python支持一种便利的for循环,它可以让你在不使用下标变量的情况下顺序遍历列表。例如,下面的代码显示列表mylist中的所有元素。

for u in myList:
    print(u)

可以这样读代码:“对于mylist中的每个元素u,输出它。”
        如果希望以不同的顺序遍历列表或者改变列表中的元素,那么仍然必须使用下标变量。
例如,下面的代码显示奇数位置上的元素。

for i in range(0, len(myList), 2):
    print(myList[i])

2.8 比较列表

        可以使用比较运算符(>、>=、<、<=、==、!=)对列表进行比较。为了进行比较,两个列表必须包含同样类型的元素。比较使用的是字典顺序:首先比较前两个元素,如果它们不同就决定了比较的结果;如果它们相同,那就继续比较接下来两个元素,一直重复这个过程,直到比较完所有的元素。下面是一些示例。

>>> listl = ["green", "red", "blue"]
>>> list2 = ["red", "blue", "green"]
>>> list2 == listl
False
>>> list2 != list1
True
>>> list2 >= listl
True
>>> list2 > list1
True
>>> list2 < list1
False
>>> list2 <= listl
False
>>>

2.9 列表解析

        列表解析提供了一种创建顺序元素列表的简洁方式。一个列表解析由多个方括号组成,方括号内包含后跟一个for子句的表达式,之后是0或多个for或if子句。列表解析可以产生一个由表达式求值结果组成的列表。这里是一些例子。

>>> list1 = [ x for x in range(5)] #Returnsalistof0,1,2,3,4
>>> list1
[0,1,2,3,4]
>>>
>>> list2 = [0.5 * x for x in list1]
>>> list2
[0.0,0.5,1.0,1.5,2.0]
>>>
>>> list3 = [x for x in list2 if x < 1.5]
>>> list3
[0.0, 0.5,1.0]
>>>

2.10 列表方法

一旦列表被创建,可以使用list类的方法(如图10-2 所示)来操作列表。

2.11 将字符串分成列表

        str类包括了split 方法,它对于将字符串中的条目分成列表是非常有用的。例如,下面的语句:

items = "Jane John Peter Susan".split()

        就会将字符串“Jane John Peter Susan”分离成列表['Jane' ,'John', 'Peter' ,'Susan']。在这种情况下,字符串中的条目是被空格分隔的。可以使用一个非空格的限定符。例如,下面的语句:

items = "09/20/2012".split("/")

将字符串“09/20/2012” 分成了列表['09','20', '2012']。

注意: Python 支持正则表达式,它是一种使用模式来匹配和分隔字符串的最有效且最有力的特征。正则表达式对于初学者来讲是复杂的。

2.12 输入列表

        可能经常需要编写代码从控制台将数据读入列表。可以在循环里每一行输入一个数据条目并将它追加到列表。例如:下面的代码将10个数字读入一个列表,每一行读一个数字。

lst = [] # Create a list
print("Enter 10 numbers: ")
for i in range(10) :
    lst.append(eval(input())

        有时候在一行中以空格分隔数据会更加方便。可以使用字符串的split方法从一行输入中提取数据。例如:下面的代码从-行读取10个空格分隔的数给列表。

# Read numbers as a string from the console,
s = input("Enter 10 numbers separated by spaces from one line: ")
items = s.split() # Extract items from the string
lst = [eval(x) for x in items] # Convert items to numbers

        调用input()来读取一-个字符串。使用s.split()来提取字符串s中被空格分隔的条目并返
回列表中的条目。最后一行通过将条目转化成数字来创建一个数字列表 。

2.13 对列表移位

        有时候,需要将列表中的元素向左或向右移动。Python并没有在list类中提供这样的方法,但是可以编写下面的函数来实现向左移。

2.14 简化代码

        列表可以大大简化某些任务的。例如:假设你希望通过给定的月份数字来得到月份的英文名。如果月份名被存储在一个列表中,那么给定月份的名字可以简单地通过下标访问。下面的代码提示用户输人月份数,然后显示它的月份名:

months = ["January", "February", "March", ...., "December"]
monthNumber = eval(input("Enter a month number (1 to 12): "))
print("The month is", months [monthNumber - 1])

        如果不使用months列表,你就只能使用一个冗长的多重if-else语句来决定月份名,如下所示:

if monthNumber == 0:
    print("The month is January")
elif monthNumber == 1:
    print("The month is February")
else:
    print("The month is December")

三、复制列表

关键点:为了将一个列表中的数据复制给另一个列表,必须将元素逐个地从源列表复制到目标列表。

        经常需要在程序中复制一个列表或列表的一部分。在某些情况下,可能会尝试使用赋值语句(=),如下所示:

list2 = list1

        但是,这条语句不会将listl1引用的列表内容复制给list2 ;事实上,它仅仅将list1引用值赋给list2。在这条语句之后,list1 和list2都将指向同一个列表,如图10-7所示。list2 之前指向的列表将不再被引用,它就变成了垃圾( garbage)。list2 所占用的内存空间将被自动收集起来被Python编译器重新使用。

为了将listl完全相同地复制给list2,可以使用:

list2 = [x for x in list1]

或者简化为:

list2 = [] + list1

四、将列表传递给函数

关键点:当列表被传递给函数时,由于列表是一个可变对象,所以列表的内容可能会在函数调用后改变。

        因为列表是一个对象,所以将列表传递给函数就像给函数传递一个对象。例如:下面的函数显示列表中的元素。

def printList(lst) :
    for element in 1st:
        print(e1 ement)

可以通过传递列表来调用它。例如:下面的语句调用printlist 函数显示3、1、2、6、4和2。

printList([3,1,2,6,4,2])

注意:前面的语句创建了一个列表,然后把它传递给函数。这里没有显示指向列表的引用变量。这样的列表被称作匿名列表。

        因为列表是可变对象,所以列表的内容可能会在函数内改变。

五、从函数返回一个列表

关键点:当函数返回一个列表时,就会返回这个列表的引用值。

        在调用函数时可以传递列表参数。函数也可以返回列表。例如:下面的函数返回了一个列表,它是另一个列表倒置的结果。

        第2行创建一个新列表result。第4~5行将名为lst的列表中的元素复制给名为result的列表。第7行返回这个列表。例如:下面的语句返回元素为6、5、4、3、2和1的新列表list2。

list1=[1,2,3,4,5,6]
list2 = reverse(list1)

注意: list 类有reverse()方法,可以调用它来倒置一个列表。

六、 查找列表

关键点:如果一个列表是排好序的,那么要查找一个列表中的某个元素,二分查找比线性查找更高效。

        查找是在列表中查找一个特定元素 的方法。例如:判定某个分数是不是包含在一个分数列表里。list 类提供了index 方法来查找并返回匹配列表中某个元素的下标。它也支持in和not in运算符以决定一个元素是否在列表中。

6.1、线性查找法

        线性查找法顺序地将关键元素key和列表中的每一个元素进行比较。它连续这样做,直到这个关键字匹配列表中的某个元素,或者在没有找到匹配元素时已经查找完整个列表。如果找到一个匹配元素,那么线性查找将返回匹配元素在列表中的下标。如果没有匹配,那么查找返回-1。程序清单10-9 中的linearSearch函数可以解释这个方法。

        为了更好地理解这个函数,使用下面的语句对程序进行跟踪。

lst = [1,4,4,2,5,-3,6,2]
i = linearSearch(1st, 4) # Returns 1
j = linearSearch(1st,-4) # Returns -1
k = linearSearch(1st, -3) # Returns 5

        线性查找函数将关键字和列表的每一个 元素进行比较。这些元素可以是任意顺序。如果这,个元素存在,那么算法在找到这个关键字之前需要平均检测列表的一半元素。因为线性查找的运行时间和列表中元素的数量成正比,所以对于大型列表而言,线性查找的效率是很低的。

6.2、 二分查找法

二分查找是对列表值进行查找的另一种常用方法。想运用二分查找法,列表中的元素必须是事先排好序的。假设列表是升序排列的,那么二分查找法会首先将关键字和列表的中间元素进行比较,这时需要考虑下面三种情况

  • 如果关键字小于列表中间的元素,那么你只需要在列表的前半部分继续寻找关键字。
  • 如果关键字等于列表中间的元素,那么查找因为找到一个匹配而结束。
  • 如果关键字大于列表中间的元素,那么你只需要在列表的后半部分继续寻找关键字。

        注意:毫无疑问,二分查找法每次比较之后都排除了一半的列表。有时排除一半的元素,有时排除一半加一个元素。假定这个列表有n个元素。为方便起见,假设n是2的幂。在第一次比较之后,n/2 个元素被留下来进行下一步比较;在第二次比较之后,(n/2) /2个元素被留下。在第k次比较之后,n/2的k次方个元素被留下进行下一步查找。当k= log2n时,列表中只剩下一个元素,只需要进行一次比较即可。因此,在用二分查找时,最坏情况下需要进行log2n+1次比较来在排序列表中找到那个元素。对于一个有着1024 (29) 个元素的列表来说,最坏情况下二分查找只需要进行11次比较,而线性查找则需要进行1023次比较。

        每一次比较之后列表中需要查找的部分就减少一半,分别用low和high来表示列表中当前要查找的第一个下标和最后一个下标。初始情况下,low 是0,而high是len(lst)-1。mid表示中间元素的下标,因此mid是(low+high)/2,图10-9 给出如何利用二分查找在列表[2,4,7,10,11,45,50,59,60,66,69,70,79]中找到关键字11。

        现在,你知道二分查找是如何工作的。下一个任务是如何用Python实现它。但是不要急于一下子就完全实现它。应该逐步开发,一次只做一步。如图10-10a所示,可以从查找的第一次迭代开始。它将关键字和列表的中间元素进行比较,这时low下标是0而high是len(lst)-1。如果key<lst[mid],将high下标指向mid-1 ;如果key==lst[mid],就找到了一个匹配对象,程序将返回mid;如果key>lst[mid],将low下标指向mid+1。

        接下来,考虑添加一个循环来实现函数以完成重复查找,如图10-10b所示。当找到这个关键字,或者当low>high还没有找到,那么这个查找结束。

        当没有找到关键字时,low 是关键字应该被插入以保证列表顺序的插入点。返回插入点要比返回-1更有用。这个函数必须返回一个负值来表示这个关键字不在列表中。能否简单地返回-low?不可以,因为关键字小于lst[0]。一个好的选择是如果关键字不在列表中则让函数返回-low-1。返回-low-1不仅表示这个值不在列表中,也表示值应该被插入的地方。

注意:线性查找法在一个小列表或未排序队列中查找元素时很有用,但是对大型列表而言效率很低,而二分查找法更高效,但是它们需要列表是提前排好序的。

七、排序列表

关键点:对列表元素进行排序的策略有很多种。选择排序和插入排序是两种常用方法。

        就像查找一样,排序也是程序设计中的一个常见任务。类list提供了sort 方法来对一个列表进行排序。

        已经有很多排序算法被开发出来。下面介绍两种简单、直观的排序算法:选择排序和插入排序。通过使用这些算法,可以学会开发和实现其他算法的有价值的技巧。

7.1、选择排序

        假设你希望对一个列表进行升序排列。选择排序会找到列表中的最小元素并将它和第一个元素交换。然后找到剩余元素中值最小的元素并和剩余列表的第一个元素交换,依此类推,直到只剩一个元素。图10-11给出如何运用选择排序对列表[2,9,5,4,8,1,6]进行排序。

        第一次尝试开发一个完整的排序程序可能是比较困难的。编写一段代码完成第一轮迭代,它找到列表的最小元素之后和列表的第一个元素互换,然后观察第二轮迭代时有什么不同,接着是第三轮,依此类推。这样观察会让你能编写一个推广到所有迭代的循环。

7.2、 插入排序

        假如想升序排列一个列表。插入排序算法是通过重复地将一个新元素插 人到一个已排好序的子列表中,直到整个列表排好序。图10-12给出如何利用插入排序对列表[2,9,5,4,8,1,6]进行排序。

 八、总结

  • 可以利用Python内置的len、max、min和sum函数返回一个列表的长度、列表的最大和最小值以及列表中所有元素之和。
  • 可以使用random模块中的shuffle函数将一个列表中的元素打乱。
  • 可以使用下标运算符[]来引用列表中的一个独立元素。
  • 程序员常常会错误地用下标1来引用列表中的第一个元素,但它应该是0。这被称为下标出1错误。
  • 可以使用连接操作符+来连接两个列表,使用复制运算符*来复制元素,使用截取运算符[:]获取一个子列表,使用in和not in运算符来检-一个元素是否在列表中。
  • 可以使用for循环来遍历列表中的所有元素。
  • 可以使用比较运算符来比较两个列表中的元素。
  • 一个列表对象是可变的。可以使用方法append、extend、insert、pop和remove向一个列表添加元素和从一个列表删除元素。
  • 可以使用index方法获取列表中一个元素的下标,使用count方法来返回列表中元素的个数。
  • 可以使用sort和reverse方法来对一个列表中的元素进行排序和翻转。
  • 可以使用split方法来将一个字符串分离成列表。
  • 当调用一个带列表参数的函数时,列表的引用则被传递给这个函数。
  • 如果一个列表已经排好序,那么在列表中查找一个元素时二分查找比线性查找效率更高。
  • 选择排序将列表中的最小元素和第一个元素交换。然后找到剩余元素中最小的元素并与剩余元素的第一个交换,依此类推,直到只剩一个元素为止。
  • 插入排序算法重复地将一个新元素插入排好序的子列表中,直到整个表都排好序为止。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/887667.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于 matplotlib module 的物理示意图绘制

基于 matplotlib module 的物理示意图绘制 # 创建画布和子图 fig, ax plt.subplots()# 去除 x 轴和 y 轴的边框线 ax.spines[bottom].set_visible(False) ax.spines[top].set_visible(False) ax.spines[left].set_visible(False) ax.spines[right].set_visible(False)# 隐藏 …

Azure如何调整虚拟机的大小

参考 https://blog.csdn.net/m0_48468018/article/details/132267096 创建虚拟机进入资源&#xff0c;点击大小选项&#xff0c;并对大小进行调整 点击如下图的cloud shell,进入Azure CLI,使用az vm resize 进行大小调整 命令中的g对应资源组&#xff0c;n对应虚拟机名称&am…

巧妙使用js IntersectionObserver实现dom懒加载

效果 源码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>IntersectionObserver</title></head><body style"text-align: center"><div id"container">…

数据库高性能架构模式

互联网业务兴起之后&#xff0c;海量用户加上海量数据的特点&#xff0c;单个数据库服务器已经难以满足业务需要&#xff0c;必须考虑数据库集群的方式来提升性能。高性能数据库集群的第一种方式是“读写分离”&#xff0c;第二种方式是“数据库分片”。 1、读写分离架构 **读…

Vue父子组件数据双向绑定

今天写一个功能时&#xff0c;遇到一些问题&#xff1a; 为什么子组件的contentList改变&#xff0c;也会将form中的trContentVOList的值改变&#xff1f; 吓的我立马去补充知识&#xff08;小白一枚&#xff09;,也借鉴了别的大佬的一些文章&#xff0c;这里自己整理一下&…

时序预测 | MATLAB实现基于CNN-GRU卷积门控循环单元的时间序列预测-递归预测未来(多指标评价)

时序预测 | MATLAB实现基于CNN-GRU卷积门控循环单元的时间序列预测-递归预测未来(多指标评价) 目录 时序预测 | MATLAB实现基于CNN-GRU卷积门控循环单元的时间序列预测-递归预测未来(多指标评价)预测结果基本介绍程序设计参考资料 预测结果 基本介绍 MATLAB实现基于CNN-GRU卷积…

华为网络篇 RIP的默认路由-30

难度2复杂度2 目录 一、实验原理 二、实验拓扑 三、实验步骤 四、实验过程 总结 一、实验原理 使用RIP搭建内部网络后&#xff0c;我们还需要在边界路由器进行相应的配置&#xff0c;否则无法与Internet通信。默认情况&#xff0c;内部的RIP路由器是不知道Internet的路由条…

Linux驱动开发之点亮三盏小灯

头文件 #ifndef __HEAD_H__ #define __HEAD_H__//LED1和LED3的硬件地址 #define PHY_LED1_MODER 0x50006000 #define PHY_LED1_ODR 0x50006014 #define PHY_LED1_RCC 0x50000A28 //LED2的硬件地址 #define PHY_LED2_MODER 0x50007000 #define PHY_LED2_ODR 0x50007014 #define…

人工智能驱动的视频分析技术:实时洞察与关键信息提供者

引言&#xff1a;人工智能在视频分析领域的应用为监控视频提供了更加智能化和高效的处理方式。通过实时分析监控视频&#xff0c;人工智能可以自动识别特定的对象、运动模式、区域异常等&#xff0c;并生成相关的报告和统计数据&#xff0c;为用户提供关键信息和洞察。本文将详…

时序预测 | MATLAB实现基于CNN-BiGRU卷积双向门控循环单元的时间序列预测-递归预测未来(多指标评价)

时序预测 | MATLAB实现基于CNN-BiGRU卷积双向门控循环单元的时间序列预测-递归预测未来(多指标评价) 目录 时序预测 | MATLAB实现基于CNN-BiGRU卷积双向门控循环单元的时间序列预测-递归预测未来(多指标评价)预测结果基本介绍程序设计参考资料 预测结果 基本介绍 MATLAB实现基于…

UVM学习知识点

UVM构建 include 和 import pkg区别.sv .svhhdl_top.sv和hvl_top.sv回顾uvm_config&#xff0c;以及自定义uvm_configverilog:parameter、defparam与 localparamtest_basebuild_phaseend_of_elaboration_phasefunction void configure_agentset_seqsend_of_elaboration_phaseuv…

NVIDIA Omniverse与GPT-4结合生成3D内容

全球各行业对 3D 世界和虚拟环境的需求呈指数级增长。3D 工作流程是工业数字化的核心&#xff0c;开发实时模拟来测试和验证自动驾驶车辆和机器人&#xff0c;操作数字孪生来优化工业制造&#xff0c;并为科学发现铺平新的道路。 如今&#xff0c;3D 设计和世界构建仍然是高度…

使用 wxPython和ECharts生成和保存HTML图表

使用wxPython和ECharts库来生成和保存HTML图表。wxPython是一个基于wxWidgets的Python GUI库&#xff0c;而ECharts是一个用于数据可视化的JavaScript库。 C:\pythoncode\blog\echartshow.py 参考网址&#xff1a;https://echarts.apache.org/v4/examples/zh/index.html 安装…

九宫格方式显示9个echarts效果

功能&#xff1a; 创建了一个简单的Web浏览器应用程序&#xff0c;使用wxPython库创建了一个主窗口&#xff0c;并在窗口中嵌入了九个Web浏览器面板。用户可以选择一个文件夹&#xff0c;并通过点击按钮打开多个网页&#xff0c;每个网页将在一个单独的Web浏览器面板中显示。这…

解决 adb install 错误INSTALL_FAILED_UPDATE_INCOMPATIBLE

最近给游戏出包&#xff0c;平台要求 v1 签名吧&#xff0c;AS 打包后&#xff0c;adb 执行安装到手机&#xff0c;我用的设备是google pixel6 , android 系统 13&#xff0c; 提示如下&#xff1a; adb install -r v5_android_202308161046.apk Performing Streamed Install a…

sql server 存储过程 set ansi_nulls set quoted_identifier,out 、output

SQL-92 标准要求在对空值(NULL) 进行等于 () 或不等于 (<>) 比较时取值为 FALSE。 当 SET ANSI_NULLS 为 ON 时&#xff0c;即使 column_name 中包含空值&#xff0c;使用 WHERE column_name NULL 的 SELECT 语句仍返回零行。即使 column_name 中包含非空值&#xff0c…

AI 绘画Stable Diffusion 研究(九)sd图生图功能详解-老照片高清修复放大

大家好&#xff0c;我是风雨无阻。 通过前面几篇文章的介绍&#xff0c;相信各位小伙伴&#xff0c;对 Stable Diffusion 这款强大的AI 绘图系统有了全新的认知。我们见识到了借助 Stable Diffusion的文生图功能&#xff0c;利用简单的几个单词&#xff0c;就可以生成完美的图片…

Java多线程实战

Java多线程实战 java多线程&#xff08;超详细&#xff09; java自定义线程池总结 Java创建线程方式 方法1&#xff0c;继承Thread类 方法2&#xff0c;实现Runable接口 方法2-2&#xff0c;匿名内部类形式lambda表达式 方法3&#xff0c;实现Callable接口&#xff0c;允许…

【Django】Task2 了解models和使用admin后台

文章目录 【Django】Task2 了解models和使用admin后台1.什么是models1.1常用字段类型说明1.2常用配置参数1.3models示例 2.使用Django的admin管理模块2.1admin管理模块介绍2.2创建管理员用户2.3定义models实体对象2.4注册对象2.5合并数据库2.6启动项目并进入管理后台 3.springb…

计算机视觉:从图像识别到目标检测的技术进展

随着人工智能领域的快速发展&#xff0c;计算机视觉技术在过去几年中取得了令人瞩目的进步。从最初的图像识别到如今的目标检测&#xff0c;技术的不断创新和突破让计算机在理解和解释图像中变得越来越强大。本文将带您走进这一令人兴奋的领域&#xff0c;探索计算机视觉从图像…