質問
このデータファイルでは、米国は「REGION」列を使用して4つの地域に分割されています。
名前が「Washington」で始まり、POPESTIMATE2015がPOPESTIMATE 2014より大きい地域1または2に属する郡を検索するクエリを作成します。
この関数は、列= ['STNAME'、 'CTYNAME']およびcensus_dfと同じインデックスIDを持つ5x2 DataFrameを返します(インデックスで昇順で並べ替えられます)。
[〜#〜]コード[〜#〜]
def answer_eight():
counties=census_df[census_df['SUMLEV']==50]
regions = counties[(counties[counties['REGION']==1]) | (counties[counties['REGION']==2])]
washingtons = regions[regions[regions['COUNTY']].str.startswith("Washington")]
grew = washingtons[washingtons[washingtons['POPESTIMATE2015']]>washingtons[washingtons['POPESTIMATES2014']]]
return grew[grew['STNAME'],grew['COUNTY']]
outcome = answer_eight()
assert outcome.shape == (5,2)
assert list (outcome.columns)== ['STNAME','CTYNAME']
print(tabulate(outcome, headers=["index"]+list(outcome.columns),tablefmt="orgtbl"))
[〜#〜]エラー[〜#〜]
---------------------------------------------------------------------------
ValueError Traceback (most recent call last)
<ipython-input-77-546e58ae1c85> in <module>()
6 return grew[grew['STNAME'],grew['COUNTY']]
7
----> 8 outcome = answer_eight()
9 assert outcome.shape == (5,2)
10 assert list (outcome.columns)== ['STNAME','CTYNAME']
<ipython-input-77-546e58ae1c85> in answer_eight()
1 def answer_eight():
2 counties=census_df[census_df['SUMLEV']==50]
----> 3 regions = counties[(counties[counties['REGION']==1]) | (counties[counties['REGION']==2])]
4 washingtons = regions[regions[regions['COUNTY']].str.startswith("Washington")]
5 grew = washingtons[washingtons[washingtons['POPESTIMATE2015']]>washingtons[washingtons['POPESTIMATES2014']]]
/opt/conda/lib/python3.5/site-packages/pandas/core/frame.py in __getitem__(self, key)
1991 return self._getitem_array(key)
1992 Elif isinstance(key, DataFrame):
-> 1993 return self._getitem_frame(key)
1994 Elif is_mi_columns:
1995 return self._getitem_multilevel(key)
/opt/conda/lib/python3.5/site-packages/pandas/core/frame.py in _getitem_frame(self, key)
2066 def _getitem_frame(self, key):
2067 if key.values.size and not com.is_bool_dtype(key.values):
-> 2068 raise ValueError('Must pass DataFrame with boolean values only')
2069 return self.where(key)
2070
ValueError: Must pass DataFrame with boolean values only
私は無知です。どこがいけないの?
ありがとう
異なる形状のdfを使用してdfをマスクしようとしていますが、これは誤りです。また、条件を渡す方法が誤って使用されています。 dfの列または系列をスカラーと比較してブールマスクを生成する場合は、条件だけを渡す必要があります。これを続けて使用する必要はありません。
def answer_eight():
counties=census_df[census_df['SUMLEV']==50]
# this is wrong you're passing the df here multiple times
regions = counties[(counties[counties['REGION']==1]) | (counties[counties['REGION']==2])]
# here you're doing it again
washingtons = regions[regions[regions['COUNTY']].str.startswith("Washington")]
# here you're doing here again also
grew = washingtons[washingtons[washingtons['POPESTIMATE2015']]>washingtons[washingtons['POPESTIMATES2014']]]
return grew[grew['STNAME'],grew['COUNTY']]
あなたが欲しい:
def answer_eight():
counties=census_df[census_df['SUMLEV']==50]
regions = counties[(counties['REGION']==1]) | (counties['REGION']==2])]
washingtons = regions[regions['COUNTY'].str.startswith("Washington")]
grew = washingtons[washingtons['POPESTIMATE2015']>washingtons['POPESTIMATES2014']]
return grew[['STNAME','COUNTY']]
def answer_eight():
df=census_df[census_df['SUMLEV']==50]
#df=census_df
df=df[(df['REGION']==1) | (df['REGION']==2)]
df=df[df['CTYNAME'].str.startswith('Washington')]
df=df[df['POPESTIMATE2015'] > df['POPESTIMATE2014']]
df=df[['STNAME','CTYNAME']]
print(df.shape)
return df.head(5)
def answer_eight():
county = census_df[census_df['SUMLEV']==50]
req_col = ['STNAME','CTYNAME']
region = county[(county['REGION']<3) & (county['POPESTIMATE2015']>county['POPESTIMATE2014']) & (county['CTYNAME'].str.startswith('Washington'))]
region = region[req_col]
return region
answer_eight()