会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132911个问题
Python 全系列/第一阶段:Python入门/控制语句 5281楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 5282楼

老师在def openfile之后,运行并选择打开文件后,会报这个错误是怎么回事呢?

下面两种写法都会报错

image.png

"""开发记事本软件的菜单"""

from tkinter.filedialog import *
from tkinter.colorchooser import *


class Application(Frame):

    def __init__(self, master=None):
        super().__init__(master)        # super()代表的是父类的定义,而不是父类对象
        self.master = master
        self.textpad = None             # textpad表示Text文本框对象
        self.pack()
        self.createWidget()

    def createWidget(self):
        # 创建主菜单栏
        menubar = Menu(root)

        # 创建子菜单
        menuFile = Menu(menubar)
        menuEdit = Menu(menubar)
        menuHelp = Menu(menubar)

        # 将子菜单加入主菜单栏
        menubar.add_cascade(label='文件(F)', menu=menuFile)
        menubar.add_cascade(label='编辑(E)', menu=menuEdit)
        menubar.add_cascade(label='帮助(H)', menu=menuHelp)

        # 添加菜单项
        menuFile.add_command(label='新建', accelerator='ctrl+n', command=self.test)
        menuFile.add_command(label='打开', accelerator='ctrl+o', command=self.openfile)
        menuFile.add_command(label='保存', accelerator='ctrl+s', command=self.test)
        menuFile.add_separator()  # 添加分割线
        menuFile.add_command(label='退出', accelerator='ctrl+q', command=self.test)

        # 将主菜单加到根窗口
        root['menu'] = menubar

        # 文本编辑区
        self.textpad = Text(root, width=65, height=30)
        self.textpad.pack()

        # 创建上下菜单
        self.contextMenu = Menu(root)
        self.contextMenu.add_command(label='背景颜色', command=self.test)

        # 右键绑定事件
        root.bind('<Button-3>', self.createContextMenu)

    def openfile(self):
        # self.textpad.delete("1.0", "end")  # 把text控件中所有的内容清空
        # with askopenfile(title="打开文本文件") as f:
        #     self.textpad.insert(INSERT, f.read())
        #     self.filename = f.name
        try:
            # 以utf-8编码打开
            with open(askopenfilename(), encoding='utf-8') as f:
                self.textpad.insert(INSERT. f.read())
                self.filename = f.name
                print(f.read())
        except UnicodeDecodeError:
            # 以GBK编码打开
            with open(askopenfilename()) as f:
                print(f.read())

    def test(self):
        pass

    def createContextMenu(self, event):
        self.contextMenu.post(event.x_root, event.y_root)


if __name__ == '__main__':
    root = Tk()
    root.geometry("450x300+200+300")
    root.title("百战程序员的简易记事本")
    app = Application(master=root)
    root.mainloop()


Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 5283楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>小米官网</title>
    <link rel="stylesheet" href="./iconfont.css">
    <link rel="stylesheet" href="./rests.css">
    <link rel="stylesheet" href="./mi.css">
</head>
<body>
    <!-- 黑色导航开始 -->
    <div class="black-nav">
        <div class="wrap">
            <ul class="left-nav">
                <li><a href="#">小米商城</a><span>|</span></li>
                <li><a href="#">MIUI</a><span>|</span></li>
                <li><a href="#">loT</a><span>|</span></li>
                <li><a href="#">云服务</a><span>|</span></li>
                <li><a href="#">有品商城</a><span>|</span></li>
                <li><a href="#">天星科技</a><span>|</span></li>
                <li><a href="#">小爱开放平台</a><span>|</span></li>
                <li><a href="#">企业团购</a><span>|</span></li>
                <li><a href="#">资质证件</a><span>|</span></li>
                <li><a href="#">协议规则</a><span>|</span></li>
                <li>
                    <a href="#">下载APP</a>
                    <span>|</span>
                    <div class="download">
                        <img src="./image/download.png" alt="">
                        <p>小米商城App</p>
                    </div>
                    <!-- 三角形 -->
                    <div class="triangle"></div>
                </li>
                <li><a href="#">智能生活</a><span>|</span></li>
                <li><a href="#">Select</a></li>
            </ul>
            <ul class="right-nav">
                <li><a href="">登陆</a><span>|</span></li>
                <li><a href="">注册</a><span>|</span></li>
                <li><a href="">消息通知</a></li>
                <li class="cart">
                    <a href="#">
                        <i class="iconfont">&#xe70b;</i>
                        <i>购物车</i>
                    </a>
                    <div class="cart-1">还没有东西</div>
                </li>
            </ul>
        </div>
    </div>
    <!-- 黑色导航结束 -->
    <!-- 白色导航开始 -->
    <div class="withe-nav">
        <div class="wrap">
            <div class="logo">
                <img src="./image/logo-mi2.png" alt="">
            </div>
            <div class="white-left-nav">
                <ul>
                    <li>
                        <a href="#">小米手机</a>
                        <div class="item">
                            <div class="wrap">
                                <ul>
                                    <li>
                                        <a href="#">
                                           <div><img src="./image/item.webp" alt=""</div> 
                                           <p>小米pro</p>
                                           <p>5200元</p>
                                        </a>
                                    </li>
                                    <li>
                                        <a href="#">
                                           <div><img src="./image/item.webp" alt=""</div> 
                                           <p>小米pro</p>
                                           <p>5200元</p>
                                        </a>
                                    </li>
                                    <li>
                                        <a href="#">
                                           <div><img src="./image/item.webp" alt=""</div> 
                                           <p>小米pro</p>
                                           <p>5200元</p>
                                        </a>
                                    </li>
                                    <li>
                                        <a href="#">
                                           <div><img src="./image/item.webp" alt=""</div> 
                                           <p>小米pro</p>
                                           <p>5200元</p>
                                        </a>
                                    </li>
                                    <li>
                                        <a href="#">
                                           <div><img src="./image/item.webp" alt=""</div> 
                                           <p>小米pro</p>
                                           <p>5200元</p>
                                        </a>
                                    </li>
                                                                 
                                </ul>
                            </div>                          
                        </div>
                    </li>
                    <li>
                        <a href="#">红米手机</a>
                    </li>
                    <li>
                        <a href="#">电视</a>
                    </li>
                    <li>
                        <a href="#">笔记本</a>
                    </li>
                    <li>
                        <a href="#">平板</a>
                    </li>
                    <li>
                        <a href="#">家电</a>
                    </li>
                    <li>
                        <a href="#">路由器</a>
                    </li>
                    <li>
                        <a href="#">服务</a>
                    </li>
                    <li>
                        <a href="#">社区</a>
                    </li>
                </ul>
            </div>
            <div class="white-right-nav">
                <input type="text" placeholder="洗衣机">
               
                <button>^</button>
            </div>
        </div>
    </div>  
    <!-- 白色导航结束 -->
</body>
</html>


WEB前端全系列/第一阶段:HTML5+CSS3模块/商城官网项目 5284楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 5285楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask视图高级 5287楼
WEB前端全系列/第十阶段:HTML5游戏方向(旧)/Canvas基础 5289楼
Python 全系列/第一阶段:Python入门/编程基本概念 5290楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 5291楼
JAVA 全系列/第八阶段:Linux入门到实战/Linux(旧) 5292楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO 流技术(旧) 5293楼

image.png

JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 5294楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637