• Python-VBA函数之旅-iter函数


    目录

    一、iter函数的常见应用场景:

    二、iter函数使用注意事项:

    三、如何用好iter函数?

    1、iter函数:

    1-1、Python:

    1-2、VBA:

    2、推荐阅读:

    个人主页:神奇夜光杯-CSDN博客 



    一、iter函数的常见应用场景:

            在Python中,iter()函数具有广泛的应用场景,主要用于创建迭代器对象,这些对象可以逐个访问集合的元素而不需要一次性加载整个集合到内存中,常见的应用场景有:

    1、遍历可迭代对象:对于任何可迭代的对象,如列表、元组、字符串、字典、集合等,都可以使用iter()函数获取其迭代器,然后通过迭代器逐个访问其元素,这在处理大量数据或需要按顺序访问数据的场景中非常有用。

    2、逐行读取大型文件:对于大型文本文件,使用迭代器可以逐行读取文件内容,而不是一次性将整个文件加载到内存中,这不仅可以节省内存,还可以提高代码的效率。

    3、实现惰性求值:生成器是一种特殊的迭代器,它只在需要时生成值,从而节省了内存。通过结合使用`iter()`函数和生成器表达式或生成器函数,可以实现惰性求值,即只在需要时才计算并返回结果,这在处理大量数据或计算密集型任务时非常有用,因为它可以避免不必要的计算和资源浪费。

    4、表示无限序列:迭代器可以用于表示无限序列,因为它们只在需要时生成数据,而不需要事先知道序列的长度,例如,可以使用迭代器来表示斐波那契数列或素数序列等。

    5、自定义迭代器:通过实现`__iter__()`和`__next__()`方法,可以创建自定义的迭代器类,这允许你定义自己的迭代逻辑,并在需要时返回特定的元素,自定义迭代器在处理复杂数据结构或实现特定算法时非常有用。

    6、与for循环结合使用:在for循环中,Python会自动处理迭代器的创建和迭代过程,但是,有时你可能需要更精细地控制迭代过程,例如提前终止迭代或跳过某些元素,在这种情况下,你可以使用iter()函数和next()函数来手动控制迭代过程,并与for循环结合使用。

            总之,iter()函数在Python编程中具有广泛的应用场景,它提供了一种灵活且高效的方式来处理可迭代对象并控制迭代过程。

    二、iter函数使用注意事项:

            在Python中使用iter()函数时,需注意以下几点:

    1、确保对象是可迭代的:在调用iter()函数之前,你需要确保传入的对象是可迭代的,可迭代对象包括列表、元组、字符串、字典、集合以及任何实现了`__iter__()`方法的自定义对象,如果你尝试对一个不可迭代的对象使用iter()函数,Python会抛出一个TypeError异常。

    2、避免重复迭代:迭代器只能从头至尾遍历一次,一旦迭代器耗尽(即所有元素都被访问过),再次尝试获取元素将引发StopIteration异常,因此,如果你需要多次遍历同一个集合,你应该在每次遍历之前重新创建迭代器。

    3、处理StopIteration异常:当你使用next()函数从迭代器中获取元素时,一旦迭代器耗尽,就会引发StopIteration异常,你通常需要捕获这个异常来避免程序崩溃;在Python中,for循环会自动处理这个异常,因此在大多数情况下你不需要显式地捕获它,但是,如果你手动使用next()函数,你应该确保正确处理这个异常。

    4、避免无限循环:当使用iter()函数结合自定义的`__iter__()`和`__next__()`方法创建迭代器时,需要确保迭代器在某个时刻能够引发StopIteration异常,以避免无限循环,否则,程序可能会陷入死循环,无法继续执行。

    5、不要混淆iter()和iterable:iter()函数用于获取一个迭代器的对象,而一个可迭代对象(iterable)是一个实现了`__iter__()`方法的对象,这两者并不相同;可迭代对象可以被转换为迭代器对象,而迭代器对象则用于遍历可迭代对象的元素。

    6、避免迭代中修改集合:在迭代一个集合(如列表或字典)时,直接修改该集合可能会导致不可预测的行为或错误,例如,在迭代列表时删除元素可能会导致迭代器跳过某些元素或引发异常。如果你需要在迭代过程中修改集合,最好先创建集合的副本,然后在副本上进行操作。

    7、性能考虑:虽然迭代器在处理大型数据集时非常有用,但它们并不总是最快的解决方案,在某些情况下,使用列表推导式或生成器表达式可能会更高效,因此,在选择使用迭代器时,需要考虑性能需求。

            总之,只有遵循这些注意事项,你才能够更安全、更有效地在Python中使用iter()函数和迭代器。

    三、如何用好iter函数?

            在Python中,iter()函数是一个强大的工具,用于获取可迭代对象的迭代器,从而可以遍历集合的元素,用好iter()函数的相关建议如下:

    1、理解迭代器概念:迭代器是一个可以记住遍历的位置的对象,它可以从头到尾访问数据集合的元素,但是只能前进不能后退;迭代器实现了`__iter__()`和`__next__()`方法,`__iter__()`方法返回迭代器对象本身,而`__next__()`方法返回下一个元素,并在没有更多元素时引发StopIteration异常。

    2、识别可迭代对象:在使用iter()函数之前,首先要确保你正在处理的对象是可迭代的。内置的可迭代对象包括列表、元组、字典、集合、字符串等;自定义的类也可以实现`__iter__()`方法,从而变得可迭代。

    3、创建迭代器:使用iter()函数可以很容易地创建迭代器,例如,`my_iter = iter(my_list)`将创建一个可以遍历`my_list`的迭代器。

    4、使用next()函数遍历元素:一旦你有了迭代器,就可以使用next()函数来获取集合中的下一个元素,当没有更多元素时,next()将引发StopIteration异常,你可以使用`try-except`块来捕获这个异常,以便在迭代完成时执行一些清理操作或退出循环。

    5、结合for循环使用:尽管你可以手动使用iter()和next()来遍历集合,但在大多数情况下,使用for循环会更方便和简洁,for循环内部会自动处理迭代器的创建和元素的获取,直到遇到StopIteration异常为止。

    6、处理无限迭代器:有些迭代器表示无限序列,例如生成器,在这种情况下,你需要确保有一个明确的退出条件或限制迭代次数,以避免无限循环。

    7、自定义迭代器:如果需要,你可以通过实现`__iter__()`和`__next__()`方法来创建自定义的迭代器类,这允许你控制迭代过程,例如实现特定的迭代逻辑或添加额外的功能。

    8、理解迭代器的优势:迭代器的一个主要优势是它们支持懒惰计算,即只在需要时生成值,这对于处理大型数据集或执行复杂计算特别有用,因为它可以节省内存并提高效率。

    1、iter函数:
    1-1、Python:
    1. # 1.函数:iter
    2. # 2.功能:
    3. # 2-1、用于根据指定的可迭代集合对象生成一个迭代器
    4. # 2-2、用于根据指定的可调用对象来生成一个迭代器
    5. # 3.语法:
    6. # 3-1、iter(object)
    7. # 3-2、iter(object, sentinel)
    8. # 4.参数:
    9. # 4-1、object:单参数形式出现,则是支持迭代的集合对象,即任意可迭代对象;若指定了sentinel参数,则必须是一个可调用的对象
    10. # 4-2、sentinel:若此参数出现,则object必须是一个可调用的对象
    11. # 5.返回值:返回一个迭代器iterator对象
    12. # 6.说明:
    13. # 7.示例:
    14. # 利用dir()函数获取函数的相关内置属性和方法
    15. print(dir(iter))
    16. # ['__call__', '__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__',
    17. # '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__name__',
    18. # '__ne__', '__new__', '__qualname__', '__reduce__', '__reduce_ex__', '__repr__', '__self__', '__setattr__', '__sizeof__',
    19. # '__str__', '__subclasshook__', '__text_signature__']
    20. # 利用help()函数获取函数的文档信息
    21. help(iter)
    22. # 应用一:遍历可迭代对象
    23. # 示例1:遍历列表
    24. my_list = [1, 2, 3, 4, 5]
    25. it = iter(my_list)
    26. try:
    27. while True:
    28. print(next(it))
    29. except StopIteration:
    30. print("遍历结束")
    31. # 1
    32. # 2
    33. # 3
    34. # 4
    35. # 5
    36. # 遍历结束
    37. # 示例2:遍历字符串
    38. my_string = "Myelsa"
    39. it = iter(my_string)
    40. try:
    41. while True:
    42. print(next(it))
    43. except StopIteration:
    44. print("遍历结束")
    45. # M
    46. # y
    47. # e
    48. # l
    49. # s
    50. # a
    51. # 遍历结束
    52. # 示例3:遍历字典的键
    53. my_dict = {'a': 1, 'b': 2, 'c': 3}
    54. it = iter(my_dict)
    55. try:
    56. while True:
    57. print(next(it))
    58. except StopIteration:
    59. print("遍历结束")
    60. # a
    61. # b
    62. # c
    63. # 遍历结束
    64. # 示例4:遍历字典的值
    65. my_dict = {'a': 1, 'b': 2, 'c': 3}
    66. it = iter(my_dict.values())
    67. try:
    68. while True:
    69. print(next(it))
    70. except StopIteration:
    71. print("遍历结束")
    72. # 1
    73. # 2
    74. # 3
    75. # 遍历结束
    76. # 示例5:使用自定义可迭代对象
    77. class MyIterable:
    78. def __init__(self, start, end):
    79. self.value = start
    80. self.end = end
    81. def __iter__(self):
    82. return self
    83. def __next__(self):
    84. if self.value < self.end:
    85. current = self.value
    86. self.value += 1
    87. return current
    88. else:
    89. raise StopIteration
    90. # 创建一个自定义可迭代对象
    91. my_iterable = MyIterable(0, 5)
    92. # 使用iter()和next()遍历它
    93. it = iter(my_iterable)
    94. try:
    95. while True:
    96. print(next(it))
    97. except StopIteration:
    98. print("遍历结束")
    99. # 0
    100. # 1
    101. # 2
    102. # 3
    103. # 4
    104. # 遍历结束
    105. # 应用二:逐行读取大型文件
    106. # 打开文件,准备读取
    107. with open('file.txt', 'r') as file:
    108. # 获取文件对象的迭代器
    109. line_iter = iter(file)
    110. try:
    111. # 循环调用next()直到抛出StopIteration异常
    112. while True:
    113. line = next(line_iter)
    114. print(line, end='')
    115. except StopIteration:
    116. # 当没有更多行时,捕获StopIteration异常并退出循环
    117. print("\n文件读取完毕")
    118. # 121314536273838390
    119. # 123
    120. # 456
    121. # 789
    122. # 587
    123. # 1024
    124. # 文件读取完毕
    125. # 应用三:实现惰性求值
    126. # 示例1:计算一个无限序列的平方数
    127. # 使用生成器表达式创建一个生成器
    128. square_gen = (x ** 2 for x in iter(int, 1)) # iter(int, 1) 创建了一个无限迭代器,从0开始递增,直到触发StopIteration(通过传递哨兵值1)
    129. # 使用next()函数惰性求值,获取平方数序列的前几个数
    130. print(next(square_gen)) # 输出: 0
    131. print(next(square_gen)) # 输出: 1
    132. print(next(square_gen)) # 输出: 4
    133. print(next(square_gen)) # 输出: 9
    134. # ... 可以继续调用next()获取更多的平方数
    135. # 如果我们想要获取前N个平方数,可以这样做:
    136. N = 10
    137. squares = [next(square_gen) for _ in range(N)]
    138. print(squares) # 输出前10个平方数
    139. # 示例2:创建一个自定义的迭代器类,并在其__iter__方法中使用iter()来实现惰性求值
    140. class LazySquares:
    141. def __init__(self, start=0):
    142. self.start = start
    143. def __iter__(self):
    144. return (x ** 2 for x in iter(int, 1))
    145. # 创建一个LazySquares对象
    146. lazy_squares = LazySquares()
    147. # 获取LazySquares对象的迭代器
    148. sq_iter = iter(lazy_squares)
    149. # 使用next()函数惰性求值,获取平方数序列的前几个数
    150. print(next(sq_iter)) # 输出: 0
    151. print(next(sq_iter)) # 输出: 1
    152. print(next(sq_iter)) # 输出: 4
    153. print(next(sq_iter)) # 输出: 9
    154. # ... 可以继续调用next()获取更多的平方数
    155. # 应用四:表示无限序列
    156. # 示例1: 无限自然数序列
    157. def natural_numbers():
    158. n = 1
    159. while True:
    160. yield n
    161. n += 1
    162. # 创建无限自然数序列的迭代器
    163. nat_nums_iter = iter(natural_numbers())
    164. # 打印前几个自然数
    165. for _ in range(10):
    166. print(next(nat_nums_iter))
    167. # 1
    168. # 2
    169. # 3
    170. # 4
    171. # 5
    172. # 6
    173. # 7
    174. # 8
    175. # 9
    176. # 10
    177. # 示例2: 无限平方数序列
    178. def square_numbers():
    179. n = 1
    180. while True:
    181. yield n ** 2
    182. n += 1
    183. # 创建无限平方数序列的迭代器
    184. sq_nums_iter = iter(square_numbers())
    185. # 打印前几个平方数
    186. for _ in range(10):
    187. print(next(sq_nums_iter))
    188. # 1
    189. # 4
    190. # 9
    191. # 16
    192. # 25
    193. # 36
    194. # 49
    195. # 64
    196. # 81
    197. # 100
    198. # 示例3: 无限斐波那契数列
    199. def fibonacci():
    200. a, b = 0, 1
    201. while True:
    202. yield a
    203. a, b = b, a + b
    204. # 创建无限斐波那契数列的迭代器
    205. fib_iter = iter(fibonacci())
    206. # 打印前几个斐波那契数
    207. for _ in range(10):
    208. print(next(fib_iter))
    209. # 0
    210. # 1
    211. # 1
    212. # 2
    213. # 3
    214. # 5
    215. # 8
    216. # 13
    217. # 21
    218. # 34
    219. # 应用五:自定义迭代器
    220. # 示例1: 自定义迭代器用于遍历列表
    221. class MyListIterator:
    222. def __init__(self, data):
    223. self.index = 0
    224. self.data = data
    225. def __iter__(self):
    226. return self
    227. def __next__(self):
    228. if self.index < len(self.data):
    229. result = self.data[self.index]
    230. self.index += 1
    231. return result
    232. else:
    233. raise StopIteration
    234. # 使用自定义迭代器
    235. my_list = [1, 2, 3, 4, 5]
    236. my_iter = MyListIterator(my_list)
    237. # 使用iter()函数获取迭代器
    238. iter_obj = iter(my_iter)
    239. # 打印列表中的元素
    240. for item in iter_obj:
    241. print(item)
    242. # 1
    243. # 2
    244. # 3
    245. # 4
    246. # 5
    247. # 示例2: 自定义迭代器用于遍历文件行
    248. class FileLineIterator:
    249. def __init__(self, file_path):
    250. self.file = open(file_path, 'r')
    251. self.line = self.file.readline()
    252. def __iter__(self):
    253. return self
    254. def __next__(self):
    255. if self.line:
    256. line = self.line
    257. self.line = self.file.readline()
    258. return line.strip()
    259. else:
    260. self.file.close()
    261. raise StopIteration
    262. # 使用自定义迭代器遍历文件行
    263. file_path = 'file.txt'
    264. file_iter = FileLineIterator(file_path)
    265. # 使用iter()函数获取迭代器
    266. iter_obj = iter(file_iter)
    267. # 打印文件的每一行
    268. for line in iter_obj:
    269. print(line)
    270. # 121314536273838390
    271. # 123
    272. # 456
    273. # 789
    274. # 587
    275. # 1024
    276. # 示例3: 自定义迭代器用于生成偶数序列
    277. class EvenNumberIterator:
    278. def __init__(self, start=0):
    279. self.number = start
    280. def __iter__(self):
    281. return self
    282. def __next__(self):
    283. if self.number % 2 == 0:
    284. result = self.number
    285. self.number += 1
    286. return result
    287. else:
    288. self.number += 1
    289. return self.__next__()
    290. # 使用自定义迭代器生成偶数
    291. even_iter = EvenNumberIterator()
    292. # 使用iter()函数获取迭代器
    293. iter_obj = iter(even_iter)
    294. # 打印前几个偶数
    295. for _ in range(10):
    296. print(next(iter_obj))
    297. # 0
    298. # 2
    299. # 4
    300. # 6
    301. # 8
    302. # 10
    303. # 12
    304. # 14
    305. # 16
    306. # 18
    307. # 应用六:与for循环结合使用
    308. # 示例1: 遍历列表
    309. my_list = [1, 2, 3, 4, 5]
    310. # 使用iter()函数获取列表的迭代器
    311. list_iter = iter(my_list)
    312. # 使用for循环遍历迭代器
    313. for item in list_iter:
    314. print(item)
    315. # 1
    316. # 2
    317. # 3
    318. # 4
    319. # 5
    320. # 示例2: 遍历字典的键
    321. my_dict = {'a': 1, 'b': 2, 'c': 3}
    322. # 使用iter()函数获取字典键的迭代器
    323. dict_keys_iter = iter(my_dict.keys())
    324. # 使用for循环遍历字典的键
    325. for key in dict_keys_iter:
    326. print(key)
    327. # a
    328. # b
    329. # c
    330. # 示例3: 遍历字典的值
    331. my_dict = {'a': 1, 'b': 2, 'c': 3}
    332. # 使用iter()函数获取字典值的迭代器
    333. dict_Values_iter = iter(my_dict.values())
    334. # 使用for循环遍历字典的值
    335. for Value in dict_Values_iter:
    336. print(Value)
    337. # 1
    338. # 2
    339. # 3
    340. # 示例4: 遍历自定义迭代器的元素
    341. class MyCustomIterator:
    342. def __init__(self, start, end):
    343. self.current = start
    344. self.end = end
    345. def __iter__(self):
    346. return self
    347. def __next__(self):
    348. if self.current < self.end:
    349. result = self.current
    350. self.current += 1
    351. return result
    352. else:
    353. raise StopIteration
    354. # 创建自定义迭代器的实例
    355. my_custom_iter = MyCustomIterator(0, 5)
    356. # 使用iter()函数获取迭代器(实际上这一步是可选的,因为my_custom_iter本身就是一个迭代器)
    357. custom_iter = iter(my_custom_iter)
    358. # 使用for循环遍历自定义迭代器的元素
    359. for item in custom_iter:
    360. print(item)
    361. # 0
    362. # 1
    363. # 2
    364. # 3
    365. # 4
    366. # 示例4: 遍历文件的行
    367. with open('file.txt', 'r') as file:
    368. # 使用iter()函数获取文件行的迭代器
    369. line_iter = iter(file)
    370. # 使用for循环遍历文件的每一行
    371. for line in line_iter:
    372. print(line.strip())
    373. # 121314536273838390
    374. # 123
    375. # 456
    376. # 789
    377. # 587
    378. # 1024
    1-2、VBA:
    略,待后补。
    2、推荐阅读:

    1、Python-VBA函数之旅-issubclass()函数

    Python算法之旅:Algorithm

    Python函数之旅:Functions 

    个人主页:神奇夜光杯-CSDN博客 
  • 相关阅读:
    Qt(day3)
    exists与not extists详细解释
    51、基于注解方式开发Spring WebFlux,实现生成背压数据,就是实现一直向客户端发送消息
    Python的整数是如何实现的
    Spring Boot之容器功能
    计算机网络:网络层
    ElasticSearch Java API 基本操作
    Juniper Networks Junos OS EX远程命令执行漏洞(CVE-2023-36845)
    Python中8种经典数据结构 之 集合
    KVC原理与数据筛选
  • 原文地址:https://blog.csdn.net/ygb_1024/article/details/138170372