xlwings.copy两种用法和匹配超链接
第一种复制整个sheet页,不能覆盖同名sheet,需先删除.
name新sheet也名称 after复制后的位置
wb.sheets('增量机会-体外刷新导入').copy(name='快照版本(勿动)',after=wb.sheets('手工录入-服务收入等预测'))
第二种类似vba复制选中区域从A到B
wb.sheets("快照版本(勿动)").range(f'2:{source_last_row}').copy(wb.sheets("增量机会-体外刷新导入").range('A5'))
#从一个已有的xls导入子项目名称的超链接到现在的xls
def add_hyperlink(path):
'''
匹配超链接
:param path:
:return:
'''
#一键匹配超链接
try:
wb = xw.Book.caller()
hyperlink_wb = load_workbook(path) #type: Workbook
ws = hyperlink_wb['Sheet1']
#获取输入超链接所在列
columns = [ i.value for i in ws[1]]
column = columns.index('子项目名称') if '子项目名称' in columns else None
#获取超链接map
if column != None:
column +=1
link_map = {}
rows = ws.max_row
for index in range(2,rows+1):
cell = ws.cell(row=index,column=column)
if cell.hyperlink:
key = cell.value
value = cell.hyperlink.target
link_map[key] = value
#获取当前wb 子项目名称 所在列
wb_columns = wb.sheets('增量机会-体外刷新导入').range('4:4').value
wb_column = wb_columns.index('子项目名称') if '子项目名称' in wb_columns else None
last_row = wb.sheets("增量机会-体外刷新导入").used_range.last_cell.row
for index in range(5,last_row+1):
cell = wb.sheets('增量机会-体外刷新导入').range(index,wb_column+1) map_res = link_map.get(cell.value)
if map_res:
cell.add_hyperlink(address=map_res,text_to_display=cell.value)
else:
cell.font.color = '#00000'
cell.characters.api.Font.Underline = False
wb.save()
except BaseException as e:
try:
print(e)
wb.sheets('config(勿动)').range('message').value = ','.join(e.args)
except:
pass
if __name__ == '__main__':
xw.serve()
#vba代码
Sub add_hyperlink()
On Error GoTo exit_
ThisWorkbook.Sheets("config(勿动)").Range("message") = ""
ThisWorkbook.Sheets("增量机会-体外刷新导入").Select
If ActiveSheet.FilterMode Then
ActiveSheet.ShowAllData
End If
fpath = pickFile()
strFileName = Replace(fpath, "\", "\\")
RunPython "import MainProgram; MainProgram.add_hyperlink('" & strFileName & "')"
exit_:
msg = ThisWorkbook.Sheets("config(勿动)").Range("message")
If msg <> "" Then
MsgBox msg
Else
MsgBox ("执行完成!")
End If
End Sub
wb.sheets('增量机会-体外刷新导入').copy(name='快照版本(勿动)',after=wb.sheets('手工录入-服务收入等预测'))
xlwings.copy两种用法和匹配超链接的更多相关文章
- android第一行代码-5.监听器的两种用法和context
监听器的两种用法 1.匿名函数设置监听器 public class MainActivity extends Activity { private Button button; @Override p ...
- Android(java)学习笔记147:textView 添加超链接(两种实现方式,,区别于WebView)
1.方式1: LinearLayout layout = new LinearLayout(this); LinearLayout.LayoutParams params = new LinearLa ...
- Android(java)学习笔记90:TextView 添加超链接(两种实现方式)
1. TextView添加超链接: TextView添加超链接有两种方式,它们有区别于WebView: (1)方式1: LinearLayout layout = new LinearLayout(t ...
- android textView 添加超链接(两种实现方式)
在textView添加超链接,有两种方式,第一种通过HTML格式化你的网址,一种是设置autolink,让系统自动识别超链接,下面为大家介绍下这两种方法的实现 在textView添加超链接,有两种方式 ...
- 多个超链接a 选中的和不选中的两种样式
<script src="http://www.jq22.com/jquery/1.8.3/jquery.min.js"> 浏览器自带的jquery库 <scri ...
- Python 使用 xlwings 往 excel中写入一列数据的两种方法
1.准备一个二维列表,然后再range后面不指定任何选项,可以输出该二维列表中数据在一列中显示,如下代码: # -*- coding:utf-8 -*- import xlwings as xw li ...
- sed匹配两种重要思想
1,sed匹配两种重要思想 屏蔽思想:遮住不想要的 挑出思想:遮住所有,挑出想要的. 2,实例 屏蔽思想: [root@lanny ~]# sed -n '2p' file.txt |sed -r ' ...
- textView 添加超链接(两种实现方式)
在textView添加超链接,有两种方式,第一种通过HTML格式化你的网址,一种是设置autolink,让系统自动识别超链接,下面为大家介绍下这两种方法的实现 在textView添加超链接,有两种方式 ...
- 解决mybatis实体类和数据库列名不匹配的两种办法
我们在实际开发中,会遇到实体类与数据库类不匹配的情况,在开发中就会产生各种各样的错误,那么我们应该怎么去解决这一类的错误呢?很简单,下面我们介绍两种解决方法: 首先我们看一下数据库和实体类不匹配的情况 ...
- 选中没有选中的复选框,匹配含有某个字符串的正则,json取值的两种方法,把变量定义在外面跟里面的区别
一.筛选没有选中的复选框:not("input:checked") 二.匹配有VARCHAR的字符串:".*VARCHAR.*?" 三.json取值的两种方法 ...
随机推荐
- C++数组(一):一维数组
C++一维数组 C++数组的定义方式 数据类型 数组名[数组长度]; 例子:int arr[3]; arr[0] = 1; arr[1] = 2; arr[2] = 3; 数据类型 数组名[数组长度] ...
- QML笔记——MouseArea的覆盖区域
问题摘要: 初学QML,今天发现一个奇怪的现象,调用MouseArea的位置不同,结果不同. 1.一个简单的qml示例 Rectangle { id: root width: 320 height: ...
- Linux docker 安装nginx 配置ssl证书
Linux docker 安装nginx 配置ssl证书 如果觉得样式不好:跳转即可 md文件复制过来有些样式会不一样) 原文地址:https://lifengying.site/archives/b ...
- idea快捷的输出常用语句
sout:System.out.println(); psvm:public static void main(String[] args) {}
- linux下安装mysql的方式
总体来说,mysql安装有两种方式,一个是源码安装,另一个是使用官方编译好的二进制文件安装. 1.使用rpm方式安装 原文地址:https://blog.csdn.net/liuxw1/article ...
- vue.config.js --- vue-cli 4.0配置
// 所有配置请参考 https://cli.vuejs.org/zh/config/ module.exports = { /** * publicPath * hash 模式下可使用 * publ ...
- react项目--路由封装
import React, { lazy } from "react"; import Home from "../views/Home"; import Lo ...
- C#封装FluentValidation
FluentValidation是一个非常强大的用于构建强类型验证规则的 .NET 框架,帮程序员解决了繁琐的校验问题,用起来非常爽,但我还是遇到了一件非常不爽的事情,如下代码所示: public c ...
- (已解决)nginx+php 上传文件大小设置。
1. 问题 上传文件过大报错,413 Request Entity Too Large. 2. 解决方法 修改配置文件,在以下两处: a. php.ini文件(php目录) 在File Uploads ...
- uniapp引入微信小程序自定义视频组件--记录
官方文档:https://zh.uniapp.dcloud.io/tutorial/miniprogram-subject.html 在 pages.json同级目录下 创建目录和文件: wxcomp ...