红烧胖大海7 2021-04-14 11:14 采纳率: 100%
浏览 249
已采纳

同样一段代码,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条回答 默认 最新

  • 关注

    应该是解析Excel包不一样把,不支持xlsx格式的文件。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同