会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132600个问题

from sqlalchemy import create_engine, Column, Integer, String, Float, Enum, Boolean, DECIMAL, Text, \
    Date, DateTime, Time, func, or_, ForeignKey
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.dialects.mysql import LONGTEXT
from sqlalchemy.orm import sessionmaker
import random
import enum
from datetime import date
from datetime import datetime
from datetime import time

# 准备数据库的一堆信息    ip  port    user  pwd   数据库的名称   按要求组织格式
HOSTNAME = '127.0.0.1'
PORT = '3306'
DATABASE = 'first_sqlalchemy'
USERNAME = 'root'
PASSWORD = '123456'

# dialect+driver://username:password@host:port/database?charset=utf8
# 按照上述的格式来 组织数据库信息
DB_URI = "mysql+pymysql://{username}:{password}@{host}:{port}/{db}?charset=utf8". \
    format(username=USERNAME, password=PASSWORD, host=HOSTNAME, port=PORT, db=DATABASE)

# 创建数据库引擎
engine = create_engine(DB_URI)
# 创建会话对象
session = sessionmaker(engine)()

# 创建一个ORM模型
Base = declarative_base(engine)


# User/news

class User(Base):
    __tablename__ = "user"
    id = Column(Integer, primary_key=True, autoincrement=True)
    uname = Column(String(50), nullable=False)

    def __repr__(self):
        return "<User(uname:%s)>" % self.uname


class News(Base):
    __tablename__ = "news"
    id = Column(Integer, primary_key=True, autoincrement=True)
    title = Column(String(50), nullable=False)
    content = Column(Text, nullable=False)
    # SQLALchemy实现外键的方法
    uid = Column(Integer, ForeignKey("user.id"))

    def __repr__(self):
        return "<News(title:%s,content=-%s)>" % (self.title, self.content)


# # 创建表
# Base.metadata.drop_all()
# Base.metadata.create_all()

# # 添加数据
# user = User(uname="momo")
# session.add(user)
# session.commit()

news1 = News(title="AAA", content="123", uid=1)
news2 = News(title="BBB", content="456", uid=1)
session.add([news1,news2])
session.commit()

image.png


老师帮我看下,传递列表

Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 24347楼
Python 全系列/第二阶段:Python 深入与提高/文件处理 24348楼
JAVA 全系列/第一阶段:JAVA 快速入门/变量、数据类型、运算符 24349楼
Python 全系列/第二阶段:Python 深入与提高/文件处理 24350楼

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编程(隐藏) 24351楼
Python 全系列/第二十三阶段:人工智能基础_机器学习理论和实战(旧)/逻辑回归 24352楼
JAVA 全系列/第一阶段:JAVA 快速入门/控制语句、方法、递归算法 24353楼
Python 全系列/第五阶段:数据库编程/python操作mysql(旧) 24354楼
JAVA 全系列/第八阶段:Linux入门到实战/Git 24356楼

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;

public class UdpReceiver extends Thread {
//接收客户端消息的线程
    private DatagramSocket datagramSocket;
    private int port;
    public UdpReceiver(DatagramSocket datagramSocket,int  port){
        this.datagramSocket = datagramSocket;
        this.port = port;
    }
    @Override
    public void run() {
        this.udpReceive();
    }
    //实现接收信息
    public void udpReceive(){
        //创建服务端接收数据的DatagramSocket 对象
        try {
            datagramSocket = new DatagramSocket(this.port);
            //创建数据缓存区
            byte [] bytes = new byte[1024];
            //创建数据报包对象
            UdpChatRoom.dp = new DatagramPacket(bytes,bytes.length);
            //等待接收客户端所发送的数据
            try {
                synchronized (UdpChatRoom.dp){
                    datagramSocket.receive(UdpChatRoom.dp);
                    //唤醒线程
                    UdpChatRoom.dp.notifyAll();
                    String str = new String(UdpChatRoom.dp.getData(),0,UdpChatRoom.dp.getLength());
                    System.out.println(str);
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        } catch (SocketException e) {
            e.printStackTrace();
        }
    }
}

public class UdpSend extends Thread {
    //向客户端发送消息的线程
    private DatagramPacket datagramPacket;
    private DatagramSocket datagramSocket;
    private String destIp;//目标IP地址
    private int desPort;//目标端口
    private Scanner scanner;

    public UdpSend(DatagramSocket datagramSocket, DatagramPacket datagramPacket, String destIp, int desPort, Scanner scanner) {
        this.datagramSocket = datagramSocket;
        this.datagramPacket = datagramPacket;
        this.destIp = destIp;
        this.desPort = desPort;
        this.scanner = scanner;
    }

    @Override
    public void run() {
        this.sendMsg();
    }

    //向客户端发送消息
    public void sendMsg() {
        while (true) {
            //消息需要进行转换转换成字符数组
            scanner = new Scanner(System.in);
            String sendMsg = scanner.nextLine();
            byte[] bytes = sendMsg.getBytes();
            //创建数据报包装对象DatagramPacket
            this.datagramPacket = new DatagramPacket(bytes, bytes.length, new InetSocketAddress(this.destIp, this.desPort));
            //将数据包放入公共数据区
            UdpChatRoom.dp = datagramPacket;
            //创建数据发送对象DatagramSocket,需要指定消息的发送端口
            try {
                this.datagramSocket = new DatagramSocket(8888);
                synchronized (datagramPacket){
                     //让发送消息的线程处于等待状态
                    datagramPacket.wait();
                    //从公共数据区取出包发送给客户端
                    this.datagramSocket.send(UdpChatRoom.dp);
                }

            } catch (SocketException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                try {
                    if (datagramSocket != null) {
                        datagramSocket.close();
                    }
                    if (datagramPacket != null) {
                        datagramSocket.close();
                    }
                    if (scanner != null) {
                        scanner.close();
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }
}
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;
import java.util.Scanner;

public class UdpChatRoom {
    //udp一对多聊天室
    //存放公共的信息
    public static DatagramPacket dp;

    public static void main(String[] args) {
        try {

            DatagramSocket datagramSocket = new DatagramSocket(8888);
            new UdpReceiver(datagramSocket,9999).start();
            new UdpSend(datagramSocket,UdpChatRoom.dp,"127.0.0.1",8888,new Scanner(System.in)).start();
        } catch (SocketException e) {
            e.printStackTrace();
        }

    }
}

老师这是我用udp写的哪个多人聊天,看看哪里有错误

JAVA 全系列/第二阶段:JAVA 基础深化和提高/网络编程(旧) 24359楼



老师我想问下这个端口为什么在不同的浏览器中显示也不一样啊,我端口为“6666”时火狐浏览器被禁止访问,idea也会报异常信息,IE浏览器就没问题。当为端口为“8888”时idea无法获取到来自浏览器任何信息,浏览器也一直显示正在连接。

异常信息:

"C:\Program Files\Java\jdk1.8.0_131\bin\java.exe" "-javaagent:D:\IDEA\IntelliJ IDEA 2019.3.2\lib\idea_rt.jar=57389:D:\IDEA\IntelliJ IDEA 2019.3.2\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.8.0_131\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_131\jre\lib\rt.jar;D:\httpsxt\out\production\httpServer_1" Server2
Exception in thread "main" java.lang.NullPointerException
	at Server2.main(Server2.java:21)

Process finished with exit code 1

image.png





JAVA 全系列/第二阶段:JAVA 基础深化和提高/手写服务器项目(旧) 24360楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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