
本文介绍如何将独立的星形图案生成函数改造为可复用模块,并嵌入到带校验的交互式输入循环中,实现用户连续输入单词(如“bal”)、实时输出对应5×5 ascii星形图案的功能。
本文介绍如何将独立的星形图案生成函数改造为可复用模块,并嵌入到带校验的交互式输入循环中,实现用户连续输入单词(如“bal”)、实时输出对应5×5 ascii星形图案的功能。
要构建一个健壮、可扩展的字母星形图案打印程序,关键在于职责分离与参数化设计:将图案逻辑封装为接收字符串参数的纯函数,将输入控制交由独立的流程管理函数,主函数仅负责协调调用。以下为完整实现与核心要点解析。
✅ 改造 pattern():从全局依赖到函数内聚
原始代码中 pattern() 依赖全局变量 name 和 list2,导致无法复用。改造后需:
- 将 name 作为函数参数传入;
- 在函数内部初始化 list2 = [],避免副作用;
- 对非法字符统一处理(当前仅支持 'B', 'A', 'L',后续易扩展)。
def pattern(name):
list2 = [] # 局部列表,存储每个字母的5x5二维字符网格
for char in name.upper(): # 统一转大写,提升鲁棒性
if char == "B":
grid = [[" " for _ in range(5)] for _ in range(5)]
for row in range(5):
for col in range(5):
if (col == 0) or \
(col == 4 and row not in {0, 2, 4}) or \
((row in {0, 2, 4}) and 0 < col < 4):
grid[row][col] = "*"
list2.append(grid)
elif char == "A":
grid = [[" " for _ in range(5)] for _ in range(5)]
for row in range(5):
for col in range(5):
if (row == 0 and 1 < col < 3) or \
((row == 1) and (0 < col < 2 or 2 < col < 4)) or \
(row == 2) or \
((row in {3, 4}) and (col == 0 or col == 4)):
grid[row][col] = "*"
list2.append(grid)
elif char == "L":
grid = [[" " for _ in range(5)] for _ in range(5)]
for row in range(5):
for col in range(5):
if col == 0 or (row == 4 and 0 < col < 5):
grid[row][col] = "*"
list2.append(grid)
else:
print(f"Warning: '{char}' is not supported. Skipping.")
continue # 跳过非法字符,不中断整个流程
return list2? 注意:原答案中 A 的条件 (3<col>=4) 是语法错误(应为 col == 4),已修正;同时优化了逻辑可读性(如用 row in {0,2,4} 替代冗长 or 链),并添加 .upper() 避免大小写敏感问题。
✅ 构建输入验证循环:information_gathering_phase()
该函数专注「输入净化」——只返回合法单词或 None(表示终止)。其核心约束是:仅允许 'B', 'A', 'L'(不区分大小写),且拒绝空输入:
def information_gathering_phase():
while True:
word = input("Enter a word from the letters 'B', 'A' and/or 'L' (or type 'stop' to stop): ").strip()
if not word:
print("Input cannot be empty. Try again.")
continue
if word.lower() == "stop":
return None
if all(c.upper() in "BAL" for c in word):
return word
else:
print("Invalid word! Only letters B, A, L are allowed. Please try again.")✅ 主控流程:main() 协调执行
main() 充当调度中心:调用输入函数 → 获取有效单词 → 调用 pattern() 生成网格 → 按行并排渲染所有字母的同一行(实现横向拼接效果):
def main():
print("? Letter Pattern Generator (B, A, L only)")
print("Type 'stop' to exit.\n")
while True:
word = information_gathering_phase()
if word is None:
print("Thanks for trying my program... Bye for now!")
break
# 生成每个字母的5x5网格列表
grids = pattern(word)
if not grids: # 空列表(如全非法字符)
continue
# 按行渲染:第i行 → 所有字母的第i行并排输出
for row_idx in range(5):
line = ""
for grid in grids:
line += "".join(grid[row_idx]) + " " # 每个字母后加空格分隔
print(line.rstrip()) # 去除末尾多余空格
print() # 字母组间空行? 后续扩展建议
- 添加全部字母:将各字母绘制逻辑抽离为独立函数(如 draw_B(), draw_A()),存入字典 CHAR_MAP = {'A': draw_A, 'B': draw_B, ...},使 pattern() 变为简洁的查表调用。
- 支持自定义尺寸:将 5 抽为参数(如 size=5),增强通用性。
- 输出至文件/图形界面:在 main() 渲染阶段增加导出选项。
通过以上结构化重构,程序具备清晰分层、高内聚低耦合、易于测试与维护的特点,为后续扩展完整26字母支持打下坚实基础。










