python xlrd 获取第一行值

python xlrd fetch first row value

我正在使用带有 python 的 xlrd 来提取 excel 数据,一切都很好,数据提取也很好,但代码只获取最后一行数据。

这是我的Excel

+-------------------+------------+------------------------+
| polling_station_1 | Cairo      | 7734                   |
+-------------------+------------+------------------------+
| polling_station_2 | Giza       | 13332                  |
+-------------------+------------+------------------------+
| polling_station_3 | Alexandria | 10901                  |
+-------------------+------------+------------------------+

这是我的代码

import xlrd

excel_sheet = xlrd.open_workbook("teacher.xlsx")
sheet1= excel_sheet.sheet_by_name('parents')

for i in range(0, sheet1.nrows):        
      row = sheet1.row_slice(i)        
      Gname = row[0].value        
      Fname = row[1].value        
      Lname = row[2].value

print Gname
print Fname
print Lname

结果

polling_station_3  
Alexandria 
10901    

这是最后一行,但我想要第一行的数据 注意:更改范围仍然显示最后一行。

有没有人想办法

import xlrd

excel_sheet = xlrd.open_workbook("teacher.xlsx")
sheet1= excel_sheet.sheet_by_name('parents')

for i in range(0, sheet1.nrows):        
    row = sheet1.row_slice(i)        
    Gname = row[0].value        
    Fname = row[1].value        
    Lname = row[2].value

# these are outside the for loop so only printed for last row
print Gname
print Fname
print Lname

    # indent them to here and they will be printed for all rows
    print Gname
    print Fname
    print Lname        
excel_sheet = xlrd.open_workbook("teacher.xlsx")
sheet1= excel_sheet.sheet_by_name('parents')
row = sheet1.row(0)  # 1st row

如果打印行输出将是

[text:u'polling_station_1', text:u'cairo', text:u'7734']

现在切片或一个一个地取值

Gname = row[0].value        
Fname = row[1].value        
Lname = row[2].value

print Gname
print Fname
print Lname 

现在结果将是

olling_station_3 
Alexandria 
10901    

如果要换行

row = sheet1.row(0)  # change row(0) Value

您遇到编码问题。通过更改打印语句,您可以看到结果。

import xlrd

excel_sheet = xlrd.open_workbook("teacher.xlsx")
sheet1= excel_sheet.sheet_by_name('parents')

for i in range(0, sheet1.nrows):        
    row = sheet1.row_slice(i)        
    Gname = row[0].value        
    Fname = row[1].value        
    Lname = row[2].value

    print Gname
    print Fname
    print Lname

您正在遍历行并且当前仅打印最终结果。

如果您不想遍历该行,请将其留给 xlrd 模块使用 sheet 方法 sheet.row_value(index) 直接获取值。请注意,它是零索引的。