formatted_boxes = [[[x1, y1], [x1, y2], [x2, y2], [x2, y1]] for sublist in ready_bag_box for x1, y1, x2, y2 in sublist] 格式化输出
时间: 2023-08-18 13:26:57 浏览: 32
这段代码的格式化输出可以使用Python的print()函数,将其放在代码块中即可:
```
formatted_boxes = [[[x1, y1], [x1, y2], [x2, y2], [x2, y1]] for sublist in ready_bag_box for x1, y1, x2, y2 in sublist]
print("Formatted Boxes:")
for box in formatted_boxes:
print(box)
```
这将会输出每个box的四个坐标点,如下所示:
```
Formatted Boxes:
[[50, 100], [50, 200], [150, 200], [150, 100]]
[[200, 300], [200, 400], [300, 400], [300, 300]]
[[50, 50], [50, 100], [100, 100], [100, 50]]
```
相关问题
优化代码 def align_annotations(formatted_sql): lines = formatted_sql.split('\n') fields = [] ass=[] comments = [] for line in lines: if line.strip(): line=line.replace('\t',' ') if line.lower().startswith(("where", "left", "on","from","and","group")): fields.append(line) ass.append('') comments.append('') elif ' as ' in line.lower() and '--' in line : parts=line.replace(' as ',' -- ').replace(' AS ',' -- ').split('--') fields.append(parts[0]) ass.append(parts[1]) comments.append(parts[2]) elif ' as ' in line.lower() and '--' not in line : parts=line.replace(' as ',' AS ').split(' AS ') fields.append(parts[0]) ass.append(parts[1]) comments.append('') elif ' as ' not in line.lower() and '--' in line : parts=line.split('--') fields.append(parts[0]) ass.append('') comments.append(parts[1]) else: fields.append(line) ass.append('') comments.append('') # 计算每列的最大长度 max_field_length = max(len(field.strip()) for field in fields if not field.lower().strip().startswith(("where", "left", "on","from","and","group","inner"))) max_as_s_length = max(len(as_s.strip()) for as_s in ass) # 格式化字段、字段类型和注释,并生成新的建表语句 formatted_lines = [] for field,as_s, comment in zip(fields,ass, comments): formatted_field = f"{field.strip()}".ljust(max_field_length) if as_s.strip(): formatted_as_s = f"AS {as_s.strip()}".ljust(max_as_s_length+3) else: formatted_as_s=''.ljust(max_as_s_length+3 ) if comment.strip(): formatted_comment = f"-- {comment}" else: formatted_comment='' formatted_line = f" {formatted_field} {formatted_as_s} {formatted_comment}" formatted_lines.append(formatted_line) formatted_select_statement = "\n".join(formatted_lines) return formatted_select_statement
这个函数的作用是将一个 SQL 查询语句中的字段、字段别名和注释对齐,并生成一个新的 SQL 查询语句。针对代码的优化建议如下:
1. 减少不必要的代码行数,比如可以将 `fields`、`ass` 和 `comments` 的初始化写在一行中,不需要每个变量单独占用一行。
2. 简化一些条件判断的逻辑,比如可以将 `line.strip()` 的结果直接作为判断条件,不需要再写一个 if 语句。
3. 使用列表推导式简化对 `fields`、`ass` 和 `comments` 列表的生成过程。
4. 将一些常量定义为函数参数或全局变量,比如 `'where', 'left', 'on', 'from', 'and', 'group', 'inner'` 这些字符串可以定义为全局变量或函数参数,方便维护和修改。
根据上述优化建议,可以得到下面的代码实现:
```python
def align_annotations(formatted_sql, keywords=None):
if not keywords:
keywords = {'where', 'left', 'on', 'from', 'and', 'group', 'inner'}
lines = formatted_sql.split('\n')
fields, ass, comments = [], [], []
for line in lines:
if line.strip():
line = line.replace('\t', ' ')
if any(line.lower().startswith(kw) for kw in keywords):
fields.append(line)
ass.append('')
comments.append('')
elif ' as ' in line.lower():
parts = line.split(' as ')
if '--' in parts[1]:
parts = parts[0], *parts[1].split('--')
fields.append(parts[0])
ass.append(parts[1])
comments.append(parts[2] if len(parts) > 2 else '')
elif '--' in line:
parts = line.split('--')
fields.append(parts[0])
ass.append('')
comments.append(parts[1])
else:
fields.append(line)
ass.append('')
comments.append('')
max_field_length = max(len(field.strip()) for field in fields if not any(field.lower().strip().startswith(kw) for kw in keywords))
max_as_s_length = max(len(as_s.strip()) for as_s in ass)
formatted_lines = [f' {f"{field.strip()}".ljust(max_field_length)} '
f'{f"AS {as_s.strip()}".ljust(max_as_s_length+3) if as_s.strip() else "".ljust(max_as_s_length+3)} '
f'{f"-- {comment}" if comment.strip() else ""}'
for field, as_s, comment in zip(fields, ass, comments)]
return "\n".join(formatted_lines)
```
这样的代码更加简洁和易于维护,同时也不会影响函数的功能。
number = 1000000 formatted_number = "{:,}".format(number) print(formatted_number)把formatted_number 改成a5
好的,你可以使用以下代码把`formatted_number`改成`a5`:
```
number = 1000000
a5 = "{:,}".format(number)
print(a5)
```
这里的关键在于用`a5`代替了`formatted_number`,而`"{:,}".format(number)`仍然是对数字进行千位分隔符格式化的语法。
相关推荐
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)