self.var_substitution() E AttributeError: 'TestCase' object has no attribute 'var_substitution'
时间: 2024-03-13 08:41:02 浏览: 17
根据您提供的错误信息,看起来您正在使用一个名为`var_substitution()`的方法,但是在当前的测试用例中找不到该方法。这个错误通常发生在以下几种情况下:
1. 您可能忘记在测试用例中定义`var_substitution()`方法。请确保在测试用例类中正确定义了该方法。
2. 您可能在测试用例中使用了错误的方法名。请检查您的代码,确保方法名拼写正确,并与测试用例类中的方法名一致。
3. 您可能在测试用例之前没有正确初始化相关的变量。请确保在调用`var_substitution()`方法之前,已经正确初始化了相关的变量。
请检查以上几点,并根据具体情况进行修正。如果您能提供更多的代码或上下文信息,我可以给出更具体的帮助。
相关问题
报错AttributeError: 'str' object has no attribute 'copy'
根据提供的引用内容,报错"AttributeError: 'str' object has no attribute 'copy'"是因为在代码中使用了字符串对象的copy方法,而字符串对象没有copy方法。要解决这个问题,你可以使用字符串的切片操作来复制字符串。下面是一个示例代码:
```python
def encrypt(m, k):
k_sub = generate_k_sub(k)
ip_displace = displace(m, IP_substitution) # 初始置换
ipl = [] # L列表
r = [] # R列表
for i in range(0, 16):
l_temp = r[i - 1]
r_temp = xor(l_temp, f(r[i - 1], k_sub[i]))
ipl.append(l_temp)
r.append(r_temp)
result = r[16] + l[16]
c = displace(result, IP_inverse_substitution)
return c
def decrypt(c, k):
k_sub = generate_k_sub(k)
ip_displace = displace(c, IP_substitution) # 初始置换
ipl = [] # L列表
r = [] # R列表
for i in range(0, 16):
l_temp = r[i - 1]
r_temp = xor(l_temp, f(r[i - 1], k_sub[15 - i]))
ipl.append(l_temp)
r.append(r_temp)
result = r[16] + l[16]
m = displace(result, IP_inverse_substitution)
return m
def bin_to_hex(bin_str):
# 将64位二进制字符串分割为每个字节(8位)
bytes_list = [bin_str[i:i+8] for i in range(0, len(bin_str), 8)]
# 每个字节转换为对应的十六进制表示
hex_str = ''.join(format(int(byte, 2), '02X') for byte in bytes_list)
return hex_str
if __name__ == '__main__':
num = int(input().strip())
M = input().strip()[2:]
K = input().strip()[2:]
plaintext = encrypt(M, K)
plaintext = plaintext.zfill(64)
print('0x' + bin_to_hex(plaintext).lower())
```
SET @@local.sql_mode= 'STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';语句写在哪里
这个语句可以写在 MySQL 的命令行终端中或者写在 MySQL 配置文件中。如果写在命令行终端中,可以在登录 MySQL 后直接输入这个语句。如果写在 MySQL 配置文件中,可以找到 my.cnf 或者 my.ini 文件,在 [mysqld] 段落中添加这个语句。具体语法如下:
```
[mysqld]
sql_mode = STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION
```
这样就可以在 MySQL 启动时默认加载该语句,避免每次登录 MySQL 后都需要手动执行这个语句。