会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 133675个问题

老师,帮忙看下我这段代码,怎么修改成读取某一列的第三行到第十行的数据啊

from openpyxl import load_workbook
from openpyxl import Workbook
import glob


all_works_names = glob.glob('d:/wenjian/4月物料.xlsx')# 读取  Excel 文件

works_names = []# 定义一个空列表存放所有的工单编号


work_name_achievements = []# 定义一个空列表存放所有的工单编号和工单标题

for work_name in all_works_names:# 遍历所有的工单
    if '~' not in work_name:# 排除每一个工单名称里面包含 '~' 的文件名称
        load_works = load_workbook(work_name)# 读取每一个工单
        work_name_achievements.append([load_works['工单']['B3':'B54'].value,load_works['工单']['C3':'C54'].value])# 取出每一个表里面的工单编号和绩效并存入变量为 `work_name_achievements` 的列表

new_book = Workbook()# 使用 openpyxl 创建表格对象

# 新建一个新的 Sheet 名称为 '所有工单物料'
# new_book['Sheet'].title = '所有工单物料'
new_sheet = new_book.create_sheet('所有工单物料',0)
# 定义行号
current_row_num = 1
# 定义姓名列号
name_col = 1
# 定义绩效行号
achievements_col = 2
# 分别定义工单编号和工单标题字段名称
new_book['所有工单物料'].cell(current_row_num, name_col, '工单编号')
new_book['所有工单物料'].cell(current_row_num, achievements_col, '工单标题')
# 每添加进来一组数据行号自增1
current_row_num += 1
# 遍历所有的绩效表名称
for work_name in all_works_names:
    # 排除每一个绩效表名称里面包含 '~' 的文件名称
    if '~' not in work_name:
        # 读取每一个绩效表
        load_work = load_workbook(work_name)
        # 取出每一个表里面的工单编号和工单标题并存入 Sheet 名称为 '所有工单物料' 的工作簿内
        new_book['所有工单物料'].cell(current_row_num, name_col, load_work['工单']['B3'].value)
        new_book['所有工单物料'].cell(current_row_num, achievements_col, load_work['工单']['C3'].value)
        # 每添加进来一组数据行号自增1
        current_row_num += 1

# 将写入的数据保存名称为 '所有工单物料.xlsx' 的 Excel 文件
new_book.save('d:/wenjian/所有工单物料.xlsx')


Python 全系列/ 第十五阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 23461楼
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Dubbo 23463楼
大数据全系列/第二阶段:大型网站高并发处理/Nginx和Keepalived高可用 23464楼
WEB前端全系列/第十阶段:Nodejs编程模块/Node.js基础 23468楼
JAVA 全系列/第十九阶段:亿级高并发电商项目/亿级高并发电商项目(旧) 23469楼
JAVA 全系列/第十九阶段:亿级高并发电商项目/亿级高并发电商项目(旧) 23470楼
JAVA 全系列/第四阶段:数据库与AI协同技术实战/Oracle 数据库的使用 23472楼
JAVA 全系列/第八阶段:生产环境部署与协同开发/Docker 23473楼

import requests
from fake_useragent import UserAgent
from lxml import etree
import os

def get_header():
    location = os.getcwd() + '/fake_useragent.json'
    ua = UserAgent(path=location)
    return ua.chrome

#发送请求
class Downloader():
    def do_download(self,url):
        print(url)
        hearders = {'User-Agent':get_header()}
        resp = requests.get(url,hearders=hearders)
        if resp.status_code == 200:
            resp.encoding = 'utf-8'
            return resp.text

#数据解析
class Parser():
    def do_parse(self,html):
        e = etree.HTML(html)
        contents = [div.xpath('string(.)').strip() for div in e.xpath('//div[@class="content"]')]
        urls = ['https://www.qiushibaike.com{}'.format(url) for url in e.xpath('//ul[@class="pagination"]/li/a/@href')]
        return contents,urls

#数据保存
class Dataoutput():
    def do_save(self,datas):
        with open('duanzi.txt1','a',encoding='utf-8') as f:
            for data in datas:
                f.write(data + '\n')



#url管理器
class URLManager():
    def __init__(self):
        self.new_url = set()
        self.old_url = set()
        #加入一个url
    def add_new_url(self,url):
        if url is not None and url != '' and url not in self.old_url:
            self.new_url.add(url)
        #加入多个url
    def add_new_urls(self,urls):
        for url in urls:
            self.add_new_url(url)
        #获取一个url
    def get_new_url(self):
        url = self.new_url.pop()
        self.old_url.add(url)
        return url
        #获取还有多少个url要爬取
    def get_new_url_size(self):
        return len(self.new_url)

        #获取是否还有url要爬取
    def have_new_url(self):
        return self.get_new_url_size()>0

#调度器
class Scheduler:
    def __init__(self):
        self.downloader = Downloader()
        self.parser = Parser()
        self.data_out_put = Dataoutput()
        self.url_manager = URLManager()
    def start(self,url):
        self.url_manager.add_new_url(url)
        while self.url_manager.have_new_url():
            url = self.url_manager.get_new_url()
            html = self.downloader.do_download(url)
            datas,urls = self.parser.do_parse(html)
            self.data_out_put.do_save(datas)
            self.url_manager.add_new_urls(urls)



if __name__ == '__main__':
    scheduler = Scheduler()
    url = 'https://www.qiushibaike.com/text/'
    scheduler.start(url)

image.png

老师,这个报错是哪儿有问题呢,没想明白

Python 全系列/第十六阶段:Python 爬虫开发/爬虫反反爬- 23474楼
JAVA 全系列/第四阶段:数据库与AI协同技术实战/JDBC技术 23475楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637