前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python列表解析式到底该怎么用?

Python列表解析式到底该怎么用?

作者头像
吾非同
发布于 2022-05-25 01:53:38
发布于 2022-05-25 01:53:38
2.5K00
代码可运行
举报
文章被收录于专栏:吾非同吾非同
运行总次数:0
代码可运行

Python 是一种极其多样化和强大的编程语言!当需要解决一个问题时,它有着不同的方法。在本文中,将会展示列表解析式(List Comprehension)。我们将讨论如何使用它?什么时候该或不该使用它?

列表解析式的优势

  • 比循环更节省时间和空间。
  • 需要更少的代码行。
  • 可将迭代语句转换为公式。

如何在 Python 中创建列表

列表解析式是一种基于现有列表创建列表的语法结构。让我们来看看创建列表的不同实现

循环

循环是创建列表的传统方式。不管你使用什么样的循环。要以这种方式创建列表,您应该:

  1. 实例化一个空列表。
  2. 循环遍历一个可迭代的(如 range)的元素。
  3. 将每个元素附加到列表的末尾。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
numbers = []
for number in range(10):
    numbers.append(number)
    
print(numbers)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

在此示例中,您实例化了一个空列表 numbers。然后使用 for 循环迭代 range(10) 并使用 append() 方法将每个数字附加到列表的末尾。

map() 对象

map() 是创建列表的另一种方法。您需要向 map() 传递一个函数和一个可迭代对象,之后它会创建一个对象。该对象包含使用指定函数执行每个迭代元素所获得的输出。

例如,我们将呈现在某些产品的价格中增加增值税的任务。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
VAT_PERCENT = 0.1  # 10%


def add_vat(price):
    return price + (price * VAT_PERCENT)
    

prices = [10.03, 8.6, 32.85, 41.5, 22.64]
grand_prices = map(add_vat, prices)
print(grand_prices)
grand_prices = list(grand_prices)
print(grand_prices)

您已经构建了 add_vat() 函数并创建了 prices 可迭代对象。您将这两个参数都传递给 map() 并收集生成的 map 对象 grand_prices,或者您可以使用 list() 轻松地将其转换为列表。

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<map object at 0x7f18721e7400>  # map(add_vat, prices)
[11.03, 9.46, 36.14, 45.65, 24.9]  # list(grand_prices)

列表解析式

现在,让我们看一下列表解析式方法!这确实是 Python 风格,并且是创建列表的更好方法。为了弄清楚这种方法有多强大,我们用一个单行代码来重写那个循环示例。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
numbers = [number for number in range(10)]
print(numbers)

输出

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

正如您所见,这是一种不可思议的方法!列表解析式看起来足够可读,您不需要编写更多代码,而只需一行。

为了更好地理解列表,请查看以下语法格式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
new_list = [expression for member in iterable]

哪种方法更有效

好的,我们已经学习了如何使用循环、map() 和列表解析式来创建列表,在您的脑海中可能会提出“哪种方法更有效”的问题。我们来分析一下吧!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import random
import timeit


VAT_PERCENT = 0.1
PRICES = [random.randrange(100) for x in range(100000)]


def add_vat(price):
    return price + (price * VAT_PERCENT)
    

def get_grand_prices_with_map():
    return list(map(add_vat, PRICES))
    

def get_grand_prices_with_comprehension():
    return [add_vat(price) for price in PRICES]
    

def get_grand_prices_with_loop():
    grand_prices = []
    for price in PRICES:
        grand_prices.append(add_vat(price))
    return grand_prices
    

print(timeit.timeit(get_grand_prices_with_map, number=100))
print(timeit.timeit(add_grand_prices_with_comprehension, number=100))
print(timeit.timeit(get_grand_prices_with_loop, number=100))

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
0.9833468980004909  # with_map
1.197223742999995   # with_comprehension
1.3564663889992516  # with_loop

正如我们现在所看到的,创建列表的最优的方法是 map(),排在第二位的是列表解析式,最后是循环

但是,方法的选择应取决于您想要实现的目标。

  • 使用 map() 可以使你的代码更高效。
  • 使用循环可以使代码的思路展现更加清晰。
  • 使用列表解析式可以您使代码更加紧凑,且较高效。这是创建列表的最佳方式,因为这种方式可读性最强。

高级解析式

条件逻辑

早些时候,我向您展示了这个公式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
new_list = [expression for member in iterable]

公式可能有些不完整。对解析式的更加完整描述增加了对可选条件的支持。将条件逻辑添加到列表解析式的最常见方法是在表达式的末尾添加条件:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
new_list = [expression for member in iterable (if conditional)]

在这里,您的条件语句正好位于右边的括号中。

条件很重要,因为它们允许列表解析式过滤掉不需要的值,这在一般情况下也可以调用 filter()

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
numbers = [number for number in range(20) if number % 2 == 0]
print(numbers)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[0, 2, 4, 6, 8, 10, 12, 14, 16, 18]

正如您所看到的那样,这个解析式收集了可被 2 整除且没有余数的数字。

如果您需要更复杂的过滤器,那么您甚至可以将条件逻辑移动到单独的函数中。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def is_prime(number):
    if number > 1:
        for el in range(2, int(number/2)+1):
            if (number % el) == 0:
                return False 
        else:
            return True
          

numbers = [number for number in range(20) if is_prime(number)]
print(numbers)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[2, 3, 5, 7, 11, 13, 17, 19]

您构建 is_prime(number) 以确定是否是素数并返回布尔值。接下来,您应该将函数添加到解析式的条件中。

该公式允许您使用条件逻辑从几个可能的输出选项中进行选择。例如,您有一个产品价格表,若有负数,您应将其转换为正数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
price_list = [1.34, 19.01, -4.2, 6, 8.78, -1,1]
normalized_price_list = [price if price > 0 else price*-1 for price in price_list]
print(normalized_price_list)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[1.34, 19.01, 4.2, 6, 8.78, 1,1]

在这里,您的表达式 price 有一个条件语句,如果 price > 0 else price*-1。这会告诉 Python,如果价格为正,则输出价格值;但如果价格为负,则将价格转换为正值。该功能很强大,考虑将条件逻辑视为其自身的函数的确是很有用的:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def normalize_price(price):
    return price if price > 0 else price*-1
    

price_list = [1.34, 19.01, -4.2, 6, 8.78, -1,1]
normalized_price_list = [normalize_price(price) for price in price_list]
print(normalized_price_list)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[1.34, 19.01, 4.2, 6, 8.78, 1,1]

集合解析式

您还可以创建一个集合解析式!它基本与列表解析式相同。不同之处在于集合解析式不包含重复项。您可以通过使用花括号取代方括号来创建集合解析式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
string = "Excellent"
unique_string = {letter for letter in string}
print(unique_string)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{"E", "e", "n", "t", "x", "c", "l"}

你的集合解析式只包含唯一的字母。这与列表不同,集合不保证项目将以特定顺序存储数据。这就是为什么集合输出的第二个字母是 e,即使字符串中的第二个字母是 x

字典解析式

字典解析式也是是类似的,但需要定义一个

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
string = "Words are but wind"
word_order = {el: ind+1 for ind, el in enumerate(string.split())}
print(word_order)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{"Words": 1, "are": 2, "but": 3, "wind": 4}

要创建 word_order 字典,请在表达式中使用花括号 ({}) 以及键值对 (el: ind+1)。

海象运算符

Python 3.8 中引入的海象运算符允许您一次解决两个问题:为变量赋值,返回该值。

假设您需要对将返回温度数据的 API 应用十次。您想要的只是 100 华氏度以上的结果。而每个请求可能都会返回不同的数据。在这种情况下,没有办法在 Python 中使用列表解析式来解决问题。可迭代成员(如果有条件)的公式表达式无法让条件将数据分配给表达式可以访问的变量。

海象运算符解决了这个问题。它允许您在执行表达式的同时将输出值分配给变量。以下示例显示了这是如何实现的,使用 get_weather_data() 生成伪天气数据:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import random


def get_weather_data():
    return random.randrange(90, 110)
    

hot_temps = [temp for item in range(20) if (temp := get_weather_data()) >= 100]
print(hot_temps)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[108, 100, 106, 103, 108, 106, 103, 104, 109, 106]

什么时候不要使用解析式

列表解析式非常有用,它可以帮助您编写清晰且易于阅读和调试的代码。但在某些情况下,它们可能会使您的代码运行速度变慢或使用更多内存。如果它让您的代码效率更低或更难理解,那么可以考虑选择另一种方式。

注意嵌套的解析式

可以通过嵌套解析式以创建列表、字典和集合的组合集合译者注:这个集合不是指 set 对象类型,而是 collection,泛指容器)。例如,假设一家公司正在跟踪一年中五个不同城市的收入。存储这些数据的完美数据结构可以是嵌套在字典解析式中的列表解析式

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cities = ['New York', 'Oklahoma', 'Toronto', 'Los Angeles', 'Miami']
budgets = {city: [0 for x in range(12)] for city in cities}
print(budgets)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
    "NewYork": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
    "Oklahoma": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
    "Toronto": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
    "LosAngeles": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
    "Miami": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
}

您使用字典解析式创建了 budgets 容器。该表达式是一个键值对,其中包含另一个解析式。此代码将快速生成城市中每个 city 的数据列表。

嵌套列表是创建矩阵的常用方法,通常用于数学目的。查看下面的代码块:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
matrix = [[x for x in range(7)] for y in range(6)]
print(matrix)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[
    [0, 1, 2, 3, 4, 5, 6],
    [0, 1, 2, 3, 4, 5, 6],
    [0, 1, 2, 3, 4, 5, 6],
    [0, 1, 2, 3, 4, 5, 6],
    [0, 1, 2, 3, 4, 5, 6],
    [0, 1, 2, 3, 4, 5, 6]
]

外部列表解析式 [... for y in range(6)] 创建了六行,而内部列表解析式 [x for x in range(7)] 将用值填充这些行中的每一行。

到目前为止,每个嵌套解析式的目标都是真正且直观的。但是,还有一些其他情况,例如创建扁平化的嵌套列表,其中的逻辑可以使您的代码非常难以阅读。让我们看下面的例子,使用嵌套列表解析式来展平一个矩阵:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
matrix = [
    [0, 1, 0],
    [1, 0, 1],
    [2, 1, 2],
]
flat = [num for row in matrix for num in row]
print(flat)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[0, 1, 0, 1, 0, 1, 2, 1, 2]

扁平化矩阵的代码确实很简洁,但是太难理解了,您应该花点时间弄清楚它是如何工作的。另一方面,如果您使用 for 循环来展平相同的矩阵,那么您的代码将更加简单易读:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
matrix = [
    [0, 1, 0],
    [1, 0, 1],
    [2, 1, 2],
]
flat = []
for row in matrix:
    for num in row:
        flat.append(num)
print(flat)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[0, 1, 0, 1, 0, 1, 2, 1, 2]

现在,您可以看到代码一次遍历矩阵的一行,在移动到下一行之前取出该行中的所有元素。

虽然嵌套列表解析式可能看起来更具有 Python 风格,但对于能够编写出您的团队可以轻松理解和修改的代码来才是更加最重要的。当选择一个方法时,您应该根据解析式是有助于还是有损于可读性来做出相应的判断。

为大型数据集使用生成器

Python 中的列表解析式通过将整个列表存储到内存中来工作。对于小型至中型列表这通常很好。如果您想将前一千个整数相加,那么列表解析式将轻松地解决此任务:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
summary = sum([x for x in range(1000)])
print(summary)

输出:499500

但是,如果您需要对十亿个数字求和呢?您可以尝试执行此操作,但您的计算机可能不会有响应。这是可能因为计算机中分配大量内存。也许您是因为计算机没有如此多的内存资源。

例如,你想要一些第一个十亿整数,那么让我们使用生成器!这可能多需要一些时间,但计算机应该可以克服它:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
summary = sum((x for x in range(1000000000)))
print(summary)

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
499999999500000000

让我们来对比一下哪种方法是更优的!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import timeit


def get_sum_with_map():
    return sum(map(lambda x: x, range(1000000000)))


def get_sum_with_generator():
    return sum((x for x in range(1000000000)))


print(timeit.timeit(get_sum_with_map, number=100))
print(timeit.timeit(get_sum_with_generator, number=100))

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
4940.844053814  # get_sum_with_map
3464.1995523349997  # get_sum_with_generator

正如您所见,生成器比 map() 高效得多。

总结

本文向您介绍了列表解析式,以及如何使用它来解决复杂的任务,而不会使您的代码变得过于困难。

现在你:

  • 学习了几种创建列表的替代方法。
  • 找出每种方法的优点。
  • 可以简化循环和 map() 调用列表解析式。
  • 理解了一种将条件逻辑添加到解析式中的方法。
  • 可以创建集合和字典解析式。
  • 学会了何时不使用解析式。
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-04-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 吾非同 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》064-Pinia 中的一些核心概念
在现代前端开发中,状态管理是确保应用程序高效、可维护的关键因素之一。随着 Vue.js 的普及,Pinia 作为其新一代状态管理库,逐渐成为开发者的热门选择。Pinia 的设计不仅简洁明了,还提供了强大的功能,旨在简化状态管理的复杂性。
愚公搬代码
2025/06/02
310
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》064-Pinia 中的一些核心概念
美团前端vue面试题_2023-05-19
Vue3最重要更新之一就是Composition API,它具有一些列优点,其中不少是针对Options API暴露的一些问题量身打造。是Vue3推荐的写法,因此掌握好Composition API应用对掌握好Vue3至关重要
用户10358241
2023/05/19
1.1K0
简单了解一下pinia的结构
一开始看,是把数据部分变成了 ref,但是仔细一看,原理是toRef。好吧,大概是为了保证响应性,自动结构了。只是还是挺无语的。
用户1174620
2022/05/09
5290
简单了解一下pinia的结构
Pinia入门-实现简单的用户状态管理
在整个应用程序中访问的数据(且不需要被持久化),例如导航栏中显示的用户信息,以及需要通过页面保留的数据,例如一个非常复杂的多步骤表格。
luciozhang
2023/04/22
7750
【vue3】详解单向数据流,大家千万不用为了某某而某某了。
vue的版本一直在不断更新,内部实现方式也是不断的优化,官网也在不断更新。 既然一切皆在不停地发展,那么我们呢?等着官网更新还是有自己的思考? 我觉得我们要走在官网的前面,而不是等官网更新后,才知道原来可以这么实现。。。
用户1174620
2024/08/03
2270
【vue3】详解单向数据流,大家千万不用为了某某而某某了。
pinia
Pinia 介绍: 状态管理工具,代替Vuex 安装: npm install pinia 配置: main.ts: import {createPinia} from 'pinia'//导入 const state = createPinia()// app.use(state)// 初始化仓库 src/store/index.ts import { defineStore } from 'pinia' import { names } from './store_name' export const
kif
2023/02/27
1920
Vue 框架学习系列五:Vue 3 与状态管理库 Pinia 的深度集成
在构建复杂的 Vue.js 应用时,状态管理是一个重要的考虑因素。Vuex 是 Vue.js 官方推荐的状态管理库,但随着 Vue 3 和 Composition API 的发布,一个新的状态管理库 Pinia 开始崭露头角。Pinia 提供了与 Vue 3 和 Composition API 更紧密的集成,同时保持了 Vuex 的核心概念,如 state、mutations、actions 和 getters。本篇文章将探讨如何在 Vue 3 应用中深度集成 Pinia。
china马斯克
2024/10/04
3410
Pinia状态管理器学习笔记,持续记录
官方文档:https://pinia.vuejs.org/ 中文文档:https://pinia.web3doc.top/
房东的狗丶
2023/02/17
1.7K0
Vue项目进阶:再谈Pinia函数式(composition API)用法
Hello大家好,前段时间写了一篇关于Pinia的composition API用法的文章《Pinia进阶:优雅的setup(函数式)写法+封装到你的企业项目》,收到了不少朋友的反馈和建议。笔者也结合最近项目情况和网友们的建议做一次优化,也算是一个比较完整的版本了,这包括:
南山种子外卖跑手
2022/04/21
3.5K0
Vue项目进阶:再谈Pinia函数式(composition API)用法
欧耶!Pinia 正式成为 vuejs 的一员
Pinia 正式成为 vuejs 官方的状态库,意味着 🍍 就是 Vuex 5.x 。 先来看早期 vue 上一个关于 Vuex 5.x 的 RFC : 描述中可以看到,Vue 5.x 主要改善以下几个特性: 同时支持 composition api 和 options api 的语法; 去掉 mutations,只有 state、getters 和 actions; 不支持嵌套的模块,通过组合 store 来代替; 更完善的 Typescript 支持; 清晰、显式的代码拆分; 而 Pinia
码农小余
2022/06/16
6740
欧耶!Pinia 正式成为 vuejs 的一员
vue3了,试试轻量化的Vuex -- Pinia?
Pinia 是 Vue.js 的轻量级状态管理库,最近很受欢迎。它使用 Vue 3 中的新反应系统来构建一个直观且完全类型化的状态管理库。
玖柒的小窝
2021/11/04
1.5K0
vue3了,试试轻量化的Vuex -- Pinia?
Vue3中使用Pinia详解
Pinia是一个专门为Vue.js设计的状态管理库,它提供了一种简单和直观的方式来管理应用程序的状态。在使用Pinia时,可以轻松地创建定义状态的存储,然后将其与Vue组件绑定,使它们能够使用该状态。和上一个博客提到的Vuex相比,Pinia 更加简单易用,体积更小,同时具有更好的 TypeScript 支持和插件系统。
九仞山
2023/10/14
1K0
Vue3之状态管理:Vuex和Pinia,孰强孰弱?
在前端开发中,状态管理器是一种用于管理应用程序全局状态的工具。它通常用于大型应用程序,可以帮助开发者更好地组织和管理状态,并提供一些强大的工具来简化状态的变更和使用。
用户6297767
2023/11/21
2.6K0
Vue3之状态管理:Vuex和Pinia,孰强孰弱?
2021-10-06 vue3-你可能需要pinia来作为状态管理
好久没写博客了,其实我之前和现在写博客的唯一目的,就是为了记录一些不重要,但是以后可能会用但会忘的资料,也就是为了以后方便自己查找。这是其一。
无道
2021/10/08
1.6K0
pinia基本使用介绍
比如开始的时候我们可以使用缓存进行同步数据,虽然很low但是它确实属于一种方案,但是这种方案的实时性很差,也就是很难做到信息的及时同步,虽然你可以写很多监听来达到一个同步的效果,但是代码维护起来就会很笨重
何处锦绣不灰堆
2022/09/21
9110
结合 Vuex 和 Pinia 做一个适合自己的状态管理 nf-state
结合 Vuex 和 Pinia, 保留需要的功能,去掉不需要的功能,修改一下看着不习惯的使用方法,最后得到了一个满足自己需要的轻量级状态管理 —— nf - state。
用户1174620
2022/05/12
9610
结合 Vuex 和 Pinia 做一个适合自己的状态管理 nf-state
Pinia不就是Vuex5?
刚开始使用vue3的时候,全局状态管理器都是使用pinia。还没去了解的时候并不明白为什么要换掉vuex,毕竟是用了好几年的状态管理器,能达到的效果和语法跟vuex几乎一模一样,所以为什么要换?
wade
2022/12/02
5890
Pinia不就是Vuex5?
一文梳理vue面试题知识点
Vue3.x 改用 Proxy 替代 Object.defineProperty。因为 Proxy 可以直接监听对象和数组的变化,并且有多达 13 种拦截方法。
bb_xiaxia1998
2022/10/24
9770
前端常见vue面试题合集
通过webpack的tree-shaking功能,可以将无用模块“剪辑”,仅打包需要的
bb_xiaxia1998
2022/11/09
7600
使用 Vue 3 与 TypeScript 构建 Web 应用: Todo
引言 界面: Vue.js 3 JavaScript 超集: TypeScript 包管理器: pnpm 前端工程化/打包: Vite 路由: Vue Router 状态管理: Pinia CSS 预处理器: Less 代码格式化: Prettier 代码质量: ESLint 预览
yiyun
2023/07/17
1.2K0
使用 Vue 3 与 TypeScript 构建 Web 应用: Todo
推荐阅读
相关推荐
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》064-Pinia 中的一些核心概念
更多 >
LV.0
这个人很懒,什么都没有留下~
目录
  • 列表解析式的优势
  • 如何在 Python 中创建列表
    • 循环
    • map() 对象
    • 列表解析式
  • 哪种方法更有效
  • 高级解析式
    • 条件逻辑
    • 集合解析式
    • 字典解析式
    • 海象运算符
  • 什么时候不要使用解析式
    • 注意嵌套的解析式
    • 为大型数据集使用生成器
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档