IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Python自动化办公之大量数据excel的处理 -> 正文阅读

[系统运维]Python自动化办公之大量数据excel的处理

起因:

有一个excel表格,它很大,里边有四千多条数据

image-20211129231508882

要求:将身份证号后8位加上姓名拼音的首字母拼接成一个字符串,作为登录系统的用户名,然后将这些数据导入到数据库中。

首先,在导入数据库之前,需要我们拿到身份证后8位和姓名拼音的首字母,然后将他们拼接在一起写入excel表格中。

这么多数据肯定不能是一行一行自己手动去拼接或者是使用excel处理,除非自己闲的蛋疼

思路其实很简单,下面是写好的代码:

import pypinyin
import xlrd
import xlwt
from pypinyin import Style, lazy_pinyin


def read():
    # 读取内容
    excel = xlrd.open_workbook(r'F:\Python_WorkSpace\学生信息处理\2017级学生数据表.xlsx')
    # print(excel.sheet_names())
    sheet1 = excel.sheet_by_name("Sheet1")  # 打开页签
    excel2 = xlwt.Workbook()
    sheet2 = excel2.add_sheet("Sheet2")
    # print(sheet1)
    nrows = sheet1.nrows  # 获取行数
    ncols = sheet1.ncols  # 获取列数
    print(nrows, ncols)  # 输出行数和列数

    for i in range(0, nrows):
        # 获取年级
        grade = sheet1.cell(i, 0).value
        # 获取专业
        major = sheet1.cell(i, 1).value
        # 获取性别
        sex = sheet1.cell(i, 3).value
        # 获取学号
        stuid = sheet1.cell(i, 4).value
        # 获取学院
        college = sheet1.cell(i, 6).value
        # 获取身份证后8位
        code = sheet1.cell(i, 5).value
        code = str(code)
        code = code[-8:]
        # print(cell)

        # 获取名字拼音首字母
        name = sheet1.cell(i, 2).value
        print(name)
        name1 = ''.join(lazy_pinyin(name, style=pypinyin.FIRST_LETTER))
        # print(name)

        # 拼接id
        id = code + name1
        print(id)

        # 写入excel
        sheet2.write(i, 0, grade)
        sheet2.write(i, 1, major)
        sheet2.write(i, 2, name)
        sheet2.write(i, 3, sex)
        sheet2.write(i, 4, stuid)
        sheet2.write(i, 5, id)
        sheet2.write(i, 6, college)
    excel2.save('test.csv')


if __name__ == '__main__':
    read()

运行结果:

image-20211129232222131

好了,然后就可以直接导入数据库了。

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-11-30 16:01:27  更:2021-11-30 16:01:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 16:08:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码