发现 Python 一个有意思的小特性,发现很合适搞成面试题。问了 AI 都不行:),欢迎来挑战~

20 天前
 xFrank

已知如下 python 代码文件(已经是全部内容):

def foo():
    print("start")
    xxxxxx
    print("end")
if __name__ == "__main__":   
    print("1111")  
    foo()
    print("2222")
问题:请将 xxxxx 替换为一行 python 代码,使这个 python 文件执行后最终输出只有 1111 和 2222
替换代码要求:只能有一个语句,只有一行;多个语句组合的不行( import 也算一个语句,因此类似 import sys; sys.xxx 的不行)

引申问题:上述替换代码要求放宽为“允许引入自带库并允许多条语句”,是否还有别的方案?

4248 次点击
所在节点    Python
42 条回复
uorz
20 天前
Gemini: yield.
maolon
20 天前


你确定你问对了 ai ?
uorz
20 天前
I completely get why you wouldn't want REPL clutter! Seeing `<generator object foo at 0x...>` splashed across your screen ruins the clean `1111` and `2222` output you're aiming for.

But here is the good news: **you actually won't see the generator object printed, even in a REPL.** Here is a reality check on how Python environments handle this:

### 1. The Block Rule (Why you are already safe)
In a standard Python REPL, Jupyter Notebook, or IPython, the interpreter only auto-prints the result of an expression if it's evaluated at the **top level**.

Because your `foo()` call is nested inside the `if __name__ == "__main__":` block, the REPL treats the entire block as a single execution unit. It does not automatically echo the return values of expressions inside that block. It will silently create the generator, discard it, and move right along to `print("2222")`.

### 2. Testing Standalone
If your concern is that you are calling `foo()` *by itself* in the REPL just to test it (outside of the `if` block), then yes, the REPL will aggressively print the generator. To suppress that, simply assign it to a throwaway variable:

```python
_ = foo()
```

---

### The "Chaotic Evil" Terminal Hack (No `yield` required)
If you absolutely despise the `yield` solution and want a completely different 1-line hack that isn't a generator, you can use an ANSI escape sequence.

Replace `xxxxxx` with:

```python
return print("\033[1A\033[2K", end="")
```

**Why this works:**
1. Python executes `print("start")`, which outputs `start` and moves the cursor to the next line.
2. The `return print(...)` line executes.
3. `\033[1A` tells your terminal to move the cursor **up** one line (back to where `start` is).
4. `\033[2K` tells your terminal to **erase** that entire line.
5. `end=""` prevents this hacky print statement from adding a new line of its own.
6. The `return` immediately exits the function, so `print("end")` is never executed.

The terminal completely deletes the evidence that `print("start")` ever happened, leaving you with just `1111` and `2222`. *(Note: This is a fun terminal UI trick, so it only works in environments that support ANSI formatting!)*
uorz
20 天前
For script: yield
For repl: return print("\033[1A\033[2K", end="")
leiuu
20 天前
gemini 网页:直接答对✅
claude 客户端 sonnet 4.6:经过提示答对✅
chatgpt 网页免费版:经过提示答对✅

提示类似:“思路不对啊 有一个关键字可以做到“
uorz
20 天前
现在这个时代,面试这种 tricky 问题根本没有任何意义,跟以前 c 时代考各种指针写法一个道理。AI 比你我更了解各种语言细节。
CatCode
20 天前
审核代码的人:这么写代码的,还提交进代码库的,建议直接开了。
tianjiyao
20 天前
奇淫巧技不足道也。。。
lchkid
20 天前


啥 AI 不行啊?我测了下连豆包都行
yuruizhe
20 天前
这纯考 python 语法细节啊
不涉及任何算法
下次可以整个考查装饰器的题目
weixind
20 天前
你们面试目的是为了考倒候选人?
whoosy
20 天前
何意味?麻烦你说下公司名,我避下雷
blakezhaothinks
20 天前
这种奇技淫巧每种语言都有很多,拿来做面试题属实逆天,就算 CPython 核心开发者也不一定了解每个细节。
blakezhaothinks
20 天前
@blakezhaothinks 不过 yield 也算不上奇技淫巧,当我没说 😄
soleils
20 天前
你面试是为了招人来干活还是为了出些"奥数"题目把人考倒看乐子?
xFrank
20 天前
我错了,给大家带来了不好的影响,麻烦管理员删除帖子。怎么 @管理员?
uorz
20 天前
我相信你内心是希望面试人回答 yield 的。经过提示,Gemini 还给出了`[__import__('os').system('cls' if __import__('os').name == 'nt' else 'clear'), print("1111"), __import__('sys').exit(print("2222"))]`这样的答案。是不是面试人没回答到心坎里去就 pass 掉?
131Ib4z7Kk3ptGyY
20 天前
@xFrank 你也不希望被 v 友骂吧,v 我 50 ,我帮你删帖
deplives
20 天前
emmmm 用这个当面试题,赶紧发下公司名给网友避避雷
back0893
20 天前
? 这种面试题是为了什么?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1202699

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX