我试图在不使用任何内置函数(除了ord((和char((和char((之外(从小写到大写的转换。遵循此处其他线程上介绍的逻辑,我想到了。
def uppercase(str_data):
ord('str_data')
str_data = str_data -32
chr('str_data')
return str_data
print(uppercase('abcd'))
但是,我收到了一个错误输出:typeError:ord((期望一个字符,但是长度为8的字符串找到了我在这里缺少什么?
您需要为输入字符串的每个字符执行ORD((。而不是输入字符串:
def uppercase(str_data):
return ''.join([chr(ord(char) - 32) for char in str_data if ord(char) >= 65])
print(uppercase('abcdé--#'))
>>> ABCDÉ
没有加入:
def uppercase(str_data):
result = ''
for char in str_data:
if ord(char) >= 65:
result += chr(ord(char) - 32)
return result
print(uppercase('abcdé--#λ'))
>>> ABCDÉΛ
最好的方法是,如果您不想使用chr()
和ord()
:
def toUppercase(s):
alphabet = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
result = ''
for x in s:
if x not in alphabet or alphabet.index(x)>=26:
result += x
else:
result += alphabet[alphabet.index(x)+26]
return result
这也处理标点符号,例如;
或.
。
更新:
根据OP的请求,这是一个没有index()
的版本:
def toUppercase(s):
alphabet = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
result = ''
for x in s:
for pos in range(52):
if alphabet[pos] == x:
i = pos
if x not in alphabet or i>=26:
result += x
else:
result += alphabet[i+26]
return result
print(toUppercase('abcdj;shjgh'))
这是一个程序,可以将字符串转换为大写,而无需使用内置功能:
Str1=input("Enter the string to be converted uppercase: ")
for i in range (0,len(Str1)):
x=ord(Str1[i])
if x>=97 and x<=122:
x=x-32
y=chr(x)
print(y,end="")
ord(( - 返回单字符串的Unicode代码点。
您必须发送一个字符串作为参数。在这里,您正在发送具有4个引起问题的字符的字符串" ABCD"。将每个字符分别发送到函数,从而对函数进行4个调用以获取结果。
使用简单的计算
,将下case>转换为上案例字母 字母代码:
def toUppercase(string):
convertedCharacter = ''
for i in string:
convertCharacter += chr( ( (ord(i)) -32) )
return convertCharacter
char=input("Enter lowercase word :")
for letter in char:
s=ord(letter)
if s>=97 and s<=122:
print(chr(s-32),end=" ")
def uppercase(str_data):
ord('str_data')
str_data = str_data -32
chr('str_data')
return str_data
print(uppercase('abcd'))
在此代码中,ORD将单个字符作为参数,但您给出了多个字符,这就是为什么它显示错误的原因。一次将单个字符转换为上情况,然后制作一个如下。
。def convert_to_lower(string):
new=""
for i in string:
j=ord(i)-32 #we are taking the ascii value because the length of lower
#case to uppercase is 32 so we are subtracting 32
if 97<=ord(i)<=122 : #here we are checking whether the charecter is lower
# case or not if lowercase then only we are converting into
#uppercase
new=new+chr(j)
else: #if the character is not the lowercase alplhaber we are taking as it is
new=new+i
print(new)
convert_to_lower("hello world")