请问python 如何让字母和数字一 一对应 输入一个字母 可以转换为...

发布网友 发布时间:2022-04-23 20:55

我来回答

5个回答

热心网友 时间:2022-04-07 12:49

因为“字母”是一个有限离散的集合,比较简单的处理方式是定义一个map:

letter_to_number = {'A': 1, 'B': 2}
letter = 'A'
number = letter_to_number[letter]  # number = 1

另外,如果这个转换关系恰好跟字母的ascii码值有某种函数关系的话,也可以这样:

letter = 'A'
number = ord(letter) - ord('A') + 1 #  number = 1

追问感谢你啊 第一个看不太懂 我直接用 index = ord(“A")-65了 哈哈 小白思维简单没办法

热心网友 时间:2022-04-07 14:07

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)

热心网友 时间:2022-04-07 15:41

这次不会上当了

热心网友 时间:2022-04-07 17:33

你一定是机器人

热心网友 时间:2022-04-07 19:41

php是最好的编程语言

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com