m0_57218953
2021-04-14 11:14
采纳率: 100%
浏览 180

同样一段代码,IDLE可以运行,Pycharm不可以,这是为什么?

import xlrd
dir_case_0='G:\\Users\\Gordon\\Desktop\\图纸.xlsm'
def get_data(dir_case_0, 图纸):
    #如果路径下xlsx文件很多,可以把文件名做一个拼接传入文件名这个参数
    # dir_case = 'F:\\code\\csdn\\cese_excel\\' + filename + '.xlsx'
    '''  
获取其中一张sheet
table = data.sheet_by_name(data.sheet_names()[0])
sheet的行数与列数
table.nrows, table.ncols
    '''
    data = xlrd.open_workbook(dir_case_0)
    table = data.sheets()[0]
    nor = table.nrows
    nol = table.ncols
    dict = {}
    for i in range(1, nor):
        for j in range(nol):
            title = table.cell_value(0, j)
            value = table.cell_value(i, j)
            # print value
            dict[title] = value
        yield dict  
'''        
• yield 是一个类似 return 的关键字,只是这个函数返回的是个生成器
• 当你调用这个函数的时候,函数内部的代码并不立马执行 ,这个函数只是返回一个生成器对象
• 当你使用for进行迭代的时候,函数中的代码才会执行
'''
if __name__ == '__main__':
    for i in get_data(r'G:\Users\Gordon\Desktop\图纸.xlsm','图纸'):
        print (i)

结果如下: 

4条回答 默认 最新

相关推荐 更多相似问题