python实现数字0开始的索引,对应Execl的字母方法

字母转数字方法:

import re
 
col = row = []
 
# 输入正确格式的定位,A2,AA2有效,AAB2无效
while len(col) == 0 or len(row) == 0 or len(col) > 1 or len(row) > 1:
    colrow = input('请输入单元格位置(例如B3,AAB3,a2, aaB4):')
    col = re.findall('([A-Za-z]+)\w+', colrow)
    row = re.findall('\w+(\d+)', colrow)
    if len(col[0]) > 2: col = [] #只接受两位字母的列标,超过2位的无效,A,AB有效,AAB无效
 
row = int(row[0]) #行标
col = col[0]
 
# 输入为A2类型
if len(col) == 1:
    col = ord(col.upper())-ord('A') + 1
# 输入为AA2类型
elif len(col) == 2:
    col_1 = ord(col[0].upper())-ord('A') + 1
    col_2 = ord(col[1].upper())-ord('A') + 1
    col = col_1*26 + col_2
     
# 获取行列数
print('Column:',col , '/ Row: ',row)

数字转字母方法:

import string

letter = string.ascii_uppercase

def num_to_letter(col, row):
  row = str(row+1)
  if col < 26:
    index = col + ord('A')
    return chr(index)+row
  else:
    col_1 = (col // 26) - 1
    col_2 = (col % 26)
    return letter[col_1]+letter[col_2]+row

print(num_to_letter(4, 4))

 

转载于:https://www.cnblogs.com/pywjh/p/11485658.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值