加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

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

发布时间:2020-12-20 10:46:43 所属栏目:Python 来源:网络整理
导读:字母转数字方法: 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( ‘

字母转数字方法:

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))

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读