1

次のような Pandas DataFrame があります。

<class 'pandas.core.frame.DataFrame'>
Int64Index: 1072 entries, 0 to 1071
Data columns (total 10 columns):
city            1072  non-null values
latitude        1072  non-null values
longitude       1072  non-null values
manufacturer    1072  non-null values
name            1072  non-null values
offering        1072  non-null values
platformID      1072  non-null values
procedure       1072  non-null values
properties      1072  non-null values
sensorID        1072  non-null values
dtypes: object(10)

properties文字列値のリストです:

df_devices.head(1).properties
Out[79]: 0    [urn:average_wind, urn:dew_point]

「urn:dew_point」エントリのみを含むレコードを選択したいのですが、それらをフィルタリングする方法がわかりません (isinまたは別の方法を使用)

4

1 に答える 1

3

applyこれを行うには、 を使用するだけです。

In [11]: df = pd.DataFrame([[['urn:dew_point'], 1]], columns=['properties', 'id'])

In [12]: df
Out[12]:
        properties  id
0  [urn:dew_point]   1

In [13]: df[df['properties'].apply(lambda x: 'urn:dew_point' in x)]
Out[13]:
        properties  id
0  [urn:dew_point]   1

これが単に文字列列の一部である場合は、次を使用できますstr.contains

In [21]: df = pd.DataFrame([['urn:dew_point', 1]], columns=['properties', 'id'])

In [22]: df['properties'].str.contains('urn:dew_point')
Out[22]:
0    True
Name: properties, dtype: bool

In [23]: df[df['properties'].str.contains('urn:dew_point')]
Out[23]:
      properties  id
0  urn:dew_point   1
于 2013-08-27T13:41:58.263 に答える