我有两个csv文件,其中包含要比较的成员列表。因此,我想有一个所有成员的列表,并指出他们出现在哪个列表中,我还想计算辍学率。我想和熊猫一起做这件事。
第一个文件:
ID,LastName,FirstName,BirthDate
1,A,a,01/01/1901
2,B,b,01/01/1902
3,C,c,01/01/1903
4,D,d,01/01/1904
第二个文件:
ID,LastName,FirstName,BirthDate
1,A,a,01/01/1901
4,D,d,01/01/1904
5,E,e,01/01/1905
6,F,f,01/01/1906
结果:
ID,LastName,FirstName,BirthDate,Old,New
1,A,a,01/01/1901,Yes,Yes
2,B,b,01/01/1902,Yes,No
3,C,c,01/01/1903,Yes,No
4,D,d,01/01/1904,Yes,Yes
5,E,e,01/01/1905,No,Yes
6,F,f,01/01/1906,No,Yes
计算衰减:不在第二个文件中的成员/两个文件中的总成员
填充"旧的";列和CCD_ 1中的";新的";df2
:中的列
df1["Old"]="Yes"
df2["New"]="Yes"
然后:
pd.merge(
df1.reset_index(),
df2.reset_index(),
how="outer"
).fillna("No").set_index("ID")
输出:
ID LastName FirstName BirthDate Old New
1 A a 01/01/1901 Yes Yes
2 B b 01/01/1902 Yes No
3 C c 01/01/1903 Yes No
4 D d 01/01/1904 Yes Yes
5 E e 01/01/1905 No Yes
6 F f 01/01/1906 No Yes
要读取csv文件,只需使用pd.read_csv("csv_path.csv")
,而要导出,可以使用pd.DataFrame
对象的to_csv
方法(例如cou可以执行pd.merge(...).to_csv("output_csv_path.csv")
(。
有关其他详细信息,请查阅熊猫的文档。