回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我试图根据两列来映射值的出现。它工作得很好,多亏了马库斯在这个<a href="https://stackoverflow.com/questions/54611708/mapping-occurrence-count-based-on-criterion-from-csv-in-python">post</a>。但是,我也希望它为没有计数的事件显示一个0(其中rating字段为空)。它当前忽略空值。在</p>
<p>电流输出为:<br/>
<a href="https://i.stack.imgur.com/wCdg0.png" rel="nofollow noreferrer"><img src="https://i.stack.imgur.com/wCdg0.png" alt="enter image description here"/></a></p>
<p>如您所见,没有出现Critical,因此它们没有显示出来。我需要它显示0,如果那些环境/评级在数据帧中没有出现。在</p>
<p>我想要的输出是:<br/>
<a href="https://i.stack.imgur.com/OuRqg.png" rel="nofollow noreferrer"><img src="https://i.stack.imgur.com/OuRqg.png" alt="enter image description here"/></a></p>
<p>基本上,我希望评分(比如Critical和othersp3)始终显示,这样即使没有Critical或Others的条目,对于该环境,它也会显示为0。在</p>
<p>以下是当前代码:<br/>
<code>csvfile = pd.read_csv("rawstats.csv", encoding = "ISO-8859-1", usecols=['Environment/s Affected', 'Rating'])</code><br/>
<code>df = pd.DataFrame(csvfile)</code><br/>
<code>df.groupby(['Environment/s Affected', (df['Rating'].isin(['1', '2']))]).size().rename(index={True: 'Critical', False: 'Others P3+'}, level=1).to_csv('summary.csv')</code></p>
<p>示例数据:<br/>
<code>Rating,Environment/s Affected
3,Env1
3,Env1
3,Env1
3,Env2
3,Env2
3,Env2
3,Env2
3,Env3
3,Env3
3,Env3
3,Env3
3,Env3
3,Env4
3,Env4
3,Env4
3,Env4
3,Env4
3,Env4
4,Test5
4,Test5
4,Test5
4,Test5
4,Test5
4,Test5
4,Test5
,Env1
,Env1
,Env3
,Env4
,Env1</code></p>
<p>谢谢!在</p>