import matplotlib.pyplot as plt import pandas as pd import seaborn as sns import numpy as np data_wait = pd.read_csv("2020年洋葱价格数据集.csv") UP_dataframes = data_wait[(data_wait["state"] == "Uttar Pradesh")] list_state = data_wait["state"].unique() max_adv = dict() min_adv = dict() for i in list_state: min_adv[i] = data_wait[(data_wait["state"] == i)]["min_price"].mean() max_adv[i] = data_wait[(data_wait["state"] == i)]["max_price"].mean() tabel_min = pd.DataFrame.from_dict(min_adv, orient="index") tabel_max = pd.DataFrame.from_dict(max_adv, orient="index") print(tabel_max,tabel_min) plt.hist(height=tabel_max[0], x=tabel_max.index) plt.show() plt.hist(height=tabel_min[0],x=tabel_min.index) plt.show()这个代码有甚恶问题
时间: 2024-01-15 21:03:55 浏览: 172
import pandas as pd.docx
这段代码有一些错误和不规范之处,具体如下:
1. 在导入库的时候,应该将其放在文件的最上面,而不是中间。
2. 在导入库的时候,应该使用规范的缩写,例如将 `matplotlib.pyplot` 缩写为 `plt`。
3. 在 `pd.read_csv` 中应该传入文件路径,而不是文件名称。
4. 在 `for` 循环中,应该使用 `UP_dataframes` 而不是 `data_wait`。
5. 在 `min_adv` 和 `max_adv` 的字典中,应该将其初始化为空字典。
6. 在 `pd.DataFrame.from_dict` 中,应该将 `orient` 参数设置为 `"columns"`,而不是 `"index"`。
7. 在 `plt.hist` 中,使用了 `height` 参数,而正确的参数是 `x`。
下面是修改后的代码:
```
import pandas as pd
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt
data_wait = pd.read_csv("2020年洋葱价格数据集.csv")
UP_dataframes = data_wait[(data_wait["state"] == "Uttar Pradesh")]
list_state = data_wait["state"].unique()
max_adv = {}
min_adv = {}
for i in list_state:
min_adv[i] = UP_dataframes[UP_dataframes["state"] == i]["min_price"].mean()
max_adv[i] = UP_dataframes[UP_dataframes["state"] == i]["max_price"].mean()
tabel_min = pd.DataFrame.from_dict(min_adv, orient="columns")
tabel_max = pd.DataFrame.from_dict(max_adv, orient="columns")
print(tabel_max, tabel_min)
plt.hist(x=tabel_max.index, weights=tabel_max[0])
plt.show()
plt.hist(x=tabel_min.index, weights=tabel_min[0])
plt.show()
```
阅读全文