I have a DataFrame with two columns: a column of int and a column of str. I understand that if I insert NaN into the int column, Pandas will convert all the int into float because there is no NaN value for an int. However, when I insert None into the str column, Pandas converts all my int to float