会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132846个问题
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器 18437楼
Python 全系列/第五阶段:数据库编程/mysql的使用 18440楼

from tkinter import *
from tkinter import messagebox
class Application(Frame):
    def __init__(self,master=None):
        super().__init__(master)
        self.master=master
        self.pack()
        self.createWidget()
    def createWidget(self):
        #创建一个标签(组件)
        self.label01=Label(self,text="百战程序员",width=10,height=2
                           ,bg="black",fg="white")
        self.label01.pack()
        self.label02=Label(self,text="姬昊余",width=15,height=1,
                           bg="red",fg="blue",font=("宋体","30"))
        self.label02.pack()

        #显示图像
        global photo #因为photo为局部变量 必须声明为全局变量,否则执行完语句,图像自动销毁,不会显示
        photo=PhotoImage(file="image/123.gif")#先创建一个photo容器
        self.label03=Label(self,image=photo)
        self.label03.pack()

        #显示多行文本
        self.label04=Label(self,text="姬昊余\n吕倩倩",borderwidth="10",relief="groove"
                           ,justify="left")
        self.label04.pack()
        #justify文本对齐方式  relief边框样式  borderwidth边框宽度

        #创建一个送花按钮
        self.btn01=Button()
        self.btn01["text"]="点击送花"
        self.btn01["command"]=self.songhua
        #songhua后边加括号就成了自动执行 不加括号为触发事件
        self.btn01.pack()
    def songhua(self):
        messagebox.showinfo("送花","送你一朵小花花")

root=Tk()
root.geometry("400x200+200+300")
root.title("一个经典的GUI")
app=Application(root)
root.mainloop()

老师 在这个createWidget方法中创建组件的时候 为什么前面都要加一个self.   为什么不可以直接创建  这样做有什么作用

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 18441楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解 18442楼

老师,这个知识点我没能理解,我不明白图中位置的 current 是如何放在循环里进行循环的? 他是什么原理?  我打印出来他们类型都不一样

image.png

class Node():
    def __init__(self, value=None, prev=None, next=None):
        self.value = value
        self.prev = prev
        self.next = next

    def __str__(self):
        return 'Node:{}'.format(self.value)


class DoubleLinkedList():
    def __init__(self):
        self.root = Node()
        self.size = 0
        self.end = None

    def append(self, value):
        node = Node(value)  # 封装节点对象
        # 判断是否已经有数据
        if not self.end:  # 如果没有节点
            self.root.next = node  # 将root的下一个节点 设置为新的node节点
            node.prev = self.root  # 设置新节点的上一个节点为root
        else:
            self.end.next = node  # 将原来最后节点的下一个节点 设置为新的node节点
            node.prev = self.end  # 将原来最后节点的上一个节点 设置为最后一个节点的节点
        self.end = node  # 更新最后 一个节点新加的节点
        self.size += 1

    def append_first(self, value):
        node = Node(value)
        # 判断是否已经连接数据
        if not self.end:  # 如果没有节点
            self.root.next = node  # 将root 节点的下一个节点设置为新的node节点
            node.prev = self.root  # 将新的bode节点的上一个节点 设置为root 节点
            self.end = node  # 更新最后一个新加的root节点
        else:
            temp = self.root.next  # 报讯原来的第一个节点
            node.next = temp  # 将新的node节点 的下一个节点 设置为原来的第一个的节点
            temp.prev = node  # 更新原来保存的第一个节点的上一个节点微信的node节点
        node.prev = self.root  # 将新的node节点 的上一个节点 设置为root节点
        self.root.next = node  # 将 root 节点间的下一个节点 设置为新的node节点
        self.size += 1

    def __iter__(self):
        current = 0
        print(type(current))
        print(type(self.end))
        if current:
            # print(dir(current))
            while current is not self.end:
                yield current.value
                current = current.next
                # print(current)
                print(type(current))
            yield current.value

    def revers_iter(self):
        current = self.end
        while current is not self.root:
            yield current
            current = current.prev
            print(current)
            print(dir(current))


if __name__ == "__main__":
    link = DoubleLinkedList()
    link.append('李白')
    link.append('貂蝉')
    link.append('王昭君')
    link.append('闵月')
    link.append('小乔')
    link.append_first('大乔')

    for v in link:
        print(v)
        
    print('*' * 10, '  返回节点 ', '*' * 10)
    
    for v in link.revers_iter():
        print(v)


Python 全系列/第十五阶段:数据结构与算法/算法与数据结构(旧) 18444楼
JAVA 全系列/第二十阶段:租房网(Spring Cloud最新架构)/租房网 18445楼

   (){
        .setTitle()setVisible()setSize()setLocation()}

    ([] ) {
        = MyGameFrame().IaunchFrame()}
}

Error:Internal error: (java.util.concurrent.ExecutionException) org.jetbrains.jps.model.serialization.CannotLoadJpsModelException: Cannot parse file C:\Users\Administrator\IdeaProjects\JavaSE\javase.iml: ParseError at [row,col]:[1,1]

Message: 文件提前结束。

java.util.concurrent.ExecutionException: org.jetbrains.jps.model.serialization.CannotLoadJpsModelException: Cannot parse file C:\Users\Administrator\IdeaProjects\JavaSE\javase.iml: ParseError at [row,col]:[1,1]

Message: 文件提前结束。

at java.base/java.util.concurrent.FutureTask.report(FutureTask.java:122)

at java.base/java.util.concurrent.FutureTask.get(FutureTask.java:191)

at org.jetbrains.jps.model.serialization.JpsProjectLoader.loadModules(JpsProjectLoader.java:384)

at org.jetbrains.jps.model.serialization.JpsProjectLoader.loadModules(JpsProjectLoader.java:331)

at org.jetbrains.jps.model.serialization.JpsProjectLoader.loadFromDirectory(JpsProjectLoader.java:199)

at org.jetbrains.jps.model.serialization.JpsProjectLoader.loadProject(JpsProjectLoader.java:98)

at org.jetbrains.jps.model.serialization.impl.JpsSerializationManagerImpl.loadModel(JpsSerializationManagerImpl.java:42)

at org.jetbrains.jps.cmdline.JpsModelLoaderImpl.loadModel(JpsModelLoaderImpl.java:50)

at org.jetbrains.jps.cmdline.BuildRunner.load(BuildRunner.java:78)

at org.jetbrains.jps.cmdline.BuildSession.runBuild(BuildSession.java:274)

at org.jetbrains.jps.cmdline.BuildSession.run(BuildSession.java:130)

at org.jetbrains.jps.cmdline.BuildMain$MyMessageHandler.lambda$channelRead0$0(BuildMain.java:232)

at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)

at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)

at java.base/java.lang.Thread.run(Thread.java:830)

Caused by: org.jetbrains.jps.model.serialization.CannotLoadJpsModelException: Cannot parse file C:\Users\Administrator\IdeaProjects\JavaSE\javase.iml: ParseError at [row,col]:[1,1]

Message: 文件提前结束。

at org.jetbrains.jps.model.serialization.JpsLoaderBase.tryLoadRootElement(JpsLoaderBase.java:86)

at org.jetbrains.jps.model.serialization.JpsLoaderBase.loadRootElement(JpsLoaderBase.java:66)

at org.jetbrains.jps.model.serialization.JpsProjectLoader.lambda$loadModules$1(JpsProjectLoader.java:359)

at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)

at com.intellij.util.concurrency.BoundedTaskExecutor.doRun(BoundedTaskExecutor.java:222)

at com.intellij.util.concurrency.BoundedTaskExecutor.access$200(BoundedTaskExecutor.java:30)

at com.intellij.util.concurrency.BoundedTaskExecutor$1.execute(BoundedTaskExecutor.java:201)

at com.intellij.util.ConcurrencyUtil.runUnderThreadName(ConcurrencyUtil.java:221)

at com.intellij.util.concurrency.BoundedTaskExecutor$1.run(BoundedTaskExecutor.java:190)

... 3 more

Caused by: org.jdom.JDOMException: ParseError at [row,col]:[1,1]

Message: 文件提前结束。

at com.intellij.openapi.util.JDOMUtil.loadUsingStaX(JDOMUtil.java:255)

at com.intellij.openapi.util.JDOMUtil.load(JDOMUtil.java:326)

at org.jetbrains.jps.model.serialization.JpsLoaderBase.tryLoadRootElement(JpsLoaderBase.java:78)

... 11 more

Caused by: javax.xml.stream.XMLStreamException: ParseError at [row,col]:[1,1]

Message: 文件提前结束。

at java.xml/com.sun.org.apache.xerces.internal.impl.XMLStreamReaderImpl.next(XMLStreamReaderImpl.java:652)

at com.intellij.openapi.util.SafeStAXStreamBuilder.build(SafeStAXStreamBuilder.java:94)

at com.intellij.openapi.util.JDOMUtil.loadUsingStaX(JDOMUtil.java:248)

... 13 more

老师,为什么我照着敲会出现这种错误??

JAVA 全系列/第一阶段:JAVA 快速入门/飞机大战小项目训练 18447楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 18450楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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