JavaScript 学习笔记7_iterable_20181206

/**********************************************************************
** author		: Bugliu
** date			: 2018-12-06
** description		: iterable
** 学习网站		: www.liaoxuefeng.com
**********************************************************************/

/*
遍历Array可以采用下标循环,遍历Map和Set无法使用下标。为了统一集合类型,
Array、Map和Set都属于iterable类型。具有iterable类型的集合可以通过新的
for ... of循环来遍历
*/

var a = ['a', 'b', 'c'];
var s = new Set(['1', '2', '3']);
var m = new Map([ [1, 'x'],[2, 'y'],[3, 'z'] ]);

// 遍历数组
for( var tmp of a )
{
	console.log( tmp );
}	

// 遍历set
for( var tmp of s )
{
	console.log( tmp );
}	

// 遍历map
for( var tmp of m )
{
	console.log( tmp );
}

/*
 for...of 与 for...in的区别
 for ... in循环由于历史遗留问题,它遍历的实际上是对象的属性名称。一个
 Array数组实际上也是一个对象,它的每个元素的索引被视为一个属性。
 当我们手动给Array对象添加了额外的属性后,for ... in循环将带来意想不
 到的意外效果. 
*/
a.name = 'hello';
for( var tmp in a )
{
	console.log( tmp );	// 0, 1, 2, name
}

// for...in循环将name包含在内,for...of只循环集合本身的元素
for( var tmp of a )
{
	console.log( tmp );	// a, b, c
}

// 更好的方法是iterable内置的forEach方法,它接收一个函数,每次迭代就
// 自动回调该函数。

// 数组的forEach用法
var a = ['a', 'b', 'c'];
a.forEach(function (element, index, array){
	// element: 指向当前元素的值
	// index:指向当前索引
	// array: 指向array对象本身
	console.log( element + ',index = ' + index );
});

/* 上面function函数中的参数名称不是固定的, 可更换
  a,index = 0
  b,index = 1
  c,index = 2
*/

// set没有索引,回调函数的前两个参数都是元素本身
var s = new Set( ['a', 'b', 'c'] );
s.forEach(function (element,sameElement, set){
	console.log( element );	// a, b, c 
});

// map的回调函数参数依次为value, key , map
var m = new Map([ [1, 'a'],[2, 'b'],[3, 'c'] ]);
m.forEach(function (value, key, map){
	console.log(value);		// a, b, c
});

// js中函数调用不要求参数必须一致,可以忽略,但你所要的参
// 数在参数列表中位置左侧的所有参数都不可省略。
var a = ['a', 'b', 'c'];
a.forEach(function(element){
	console.log(element);	//a, b, c
});

// 可以忽略所有参数
a.forEach(function(){
	console.log(arguments);
});

/* 执行结果
"a", 0, Array(3), callee: ƒ, Symbol(Symbol.iterator): ƒ
"b", 1, Array(3), callee: ƒ, Symbol(Symbol.iterator): ƒ
"c", 2, Array(3), callee: ƒ, Symbol(Symbol.iterator): ƒ
*/

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: chain.from_iterable是一个函数,它可以将多个可迭代对象中的元素串联起来,返回一个迭代器。例如,如果有两个列表[1, 2, 3]和[4, 5, 6],那么使用chain.from_iterable可以将它们串联起来,得到一个迭代器[1, 2, 3, 4, 5, 6]。这个函数在处理多个可迭代对象时非常方便,可以避免使用嵌套循环的复杂性。 ### 回答2: `chain.from_iterable` 是 `itertools` 模块中的一个函数,它用于将可迭代对象(iterable)的元素逐个连接起来,返回一个新的迭代器。 这个函数的作用类似于 `itertools.chain` 函数,不同之处在于 `chain.from_iterable` 可以接受一个可迭代对象的可迭代对象作为参数,并将其中的元素逐个连接起来。 举个例子来说,如果有一个二维列表 `[[1, 2, 3], [4, 5, 6], [7, 8, 9]]`,如果我们想要将其中的所有元素连接为一个单一的迭代器,我们可以使用 `chain.from_iterable` 函数来实现: ```python import itertools two_dimensional_list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] flattened_list = itertools.chain.from_iterable(two_dimensional_list) for item in flattened_list: print(item) # 输出:1, 2, 3, 4, 5, 6, 7, 8, 9 ``` 通过使用 `chain.from_iterable` 函数,我们便可以将二维列表中的所有元素连接起来,得到一个迭代器,可以方便地遍历其中的元素。 需要注意的是,`chain.from_iterable` 返回的是一个迭代器对象,如果需要得到一个列表或其他类型的可迭代对象,可以使用 `list()` 函数转换。 ### 回答3: chain.from_iterable 可以理解为将可迭代对象中的多个嵌套的子可迭代对象展开成一个扁平的迭代器,实现了多个嵌套的可迭代对象合并为一个可迭代对象的功能。 举个例子,如果我们有一个嵌套列表 [[1, 2, 3], [4, 5, 6], [7, 8, 9]],可以使用 chain.from_iterable 将其展开成一个扁平的迭代器 [1, 2, 3, 4, 5, 6, 7, 8, 9]。以下是使用 chain.from_iterable 的代码示例: ```python from itertools import chain nested_list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] flatten_list = list(chain.from_iterable(nested_list)) print(flatten_list) # 输出:[1, 2, 3, 4, 5, 6, 7, 8, 9] ``` 在这个示例中,我们首先导入了 itertools 模块中的 chain 函数。然后,我们定义了一个嵌套列表 nested_list。通过调用 chain.from_iterable(nested_list),我们将嵌套列表展开为一个迭代器。最后,我们使用 list() 函数将迭代器转换为列表,并打印输出。 总之,chain.from_iterable 是一个方便的函数,可以将多个嵌套的可迭代对象展开成一个扁平的迭代器,以便更方便地处理和使用数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值