import pandas as pd
from ipaddr import IPv4Address
df = pd.DataFrame([[1,'192.168.1.10', '45.7.12.34', 'abc'],[4, '10.10.1.11', '90.90.67.33', 'def'], [77, '52.1.7.90', '67.5.3.5', 'ghi' ], [90, '19.19.90.7', '77.88.99.44', 'xyz']], columns=['A', 'sip', 'dip', 'location'])
addrs = [(int)(IPv4Address(addr)) for addr in df[['sip', 'dip']].values.flatten().tolist()]
我想知道在转换为列表之前是否有一种numpy
本机方式将函数应用于数组的每个元素?
答案 0 :(得分:1)
使用熊猫(因为它已被标记),您还可以尝试使用来自香草python的series.map
和map
:
[*map(int,df[['sip', 'dip']].stack().map(IPv4Address))]
#or list(map(int,df[['sip', 'dip']].stack().map(IPv4Address)))
#or df[['sip', 'dip']].stack().map(IPv4Address).astype('int64').tolist()
[3232235786,
755436578,
168427787,
1515864865,
872482650,
1124401925,
320035335,
1297638188]