Python - 包含字符串和整数的拆分列表

Python - Splitting List That Contains Strings and Integers(Python - 包含字符串和整数的拆分列表)
本文介绍了Python - 包含字符串和整数的拆分列表的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

myList = [ 4,'a', 'b', 'c', 1 'd', 3]

如何将这个列表分成两个列表,一个包含字符串,另一个包含 elegant/pythonic 方式的整数?

how to split this list into two list that one contains strings and other contains integers in elegant/pythonic way?

输出:

myStrList = [ 'a', 'b', 'c', 'd' ]

myIntList = [ 4, 1, 3 ]

注意:没有实现这样的列表,只是考虑如何为这样的问题找到一个优雅的答案(有吗?).

NOTE: didn't implemented such a list, just thought about how to find an elegant answer (is there any?) to such a problem.

推荐答案

正如其他人在评论中提到的那样,您应该真正开始考虑如何摆脱包含非同质数据的列表.但是,如果这真的 不能 完成,我会使用默认字典:

As others have mentioned in the comments, you should really start thinking about how you can get rid of the list which holds in-homogeneous data in the first place. However, if that really can't be done, I'd use a defaultdict:

from collections import defaultdict
d = defaultdict(list)
for x in myList:
   d[type(x)].append(x)

print d[int]
print d[str]

这篇关于Python - 包含字符串和整数的拆分列表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)