如何在for循环中创建数据框?

时间:2020-10-30 08:48:33

标签: python pandas dataframe

我想创建一个数据框,其中包含在for循环中获取的值。

columns = ['BIN','Date_of_registration', 'Tax','TaxName','KBK',
           'KBKName','Paynum','Paytype', 'EntryType','Writeoffdate', 'Summa']
df = pd.DataFrame(columns=columns)

我有这个for循环:

    for elements in tree.findall('{http://xmlns.kztc-cits/sign}payment'):

        print("hello")
        tax = elements.find('{http://xmlns.kztc-cits/sign}TaxOrgCode').text
        tax_name_ru = elements.find('{http://xmlns.kztc-cits/sign}NameTaxRu').text
        kbk = elements.find('{http://xmlns.kztc-cits/sign}KBK').text
        kbk_name_ru = elements.find('{http://xmlns.kztc-cits/sign}KBKNameRu').text
        paynum = elements.find('{http://xmlns.kztc-cits/sign}PayNum').text
        paytype = elements.find('{http://xmlns.kztc-cits/sign}PayType').text
        entry_type = elements.find('{http://xmlns.kztc-cits/sign}EntryType').text
        writeoffdate = elements.find('{http://xmlns.kztc-cits/sign}WriteOffDate').text
        summa = elements.find('{http://xmlns.kztc-cits/sign}Summa').text


        print(tax, tax_name_ru, kbk, kbk_name_ru, paynum, paytype, entry_type, writeoffdate, summa)

如何将获取的值附加到最初创建的(循环之外)数据帧?

1 个答案:

答案 0 :(得分:0)

如果在循环完成后仅需要数据框,则一种简单的方法是将数据附加到列表列表中,然后转换为数据框。警告:您有责任确保列表顺序与列匹配,因此,如果将来更改列,则必须重新定位列表。

list_of_rows = []
for elements in tree.findall('{http://xmlns.kztc-cits/sign}payment'):
   list_of_rows.append([
      tax, tax_name_ru, kbk, kbk_name_ru, paynum, paytype,entry_type, writeoffdate, summa])

df = pd.DataFrame(columns=columns, data=list_of_rows)