会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132382个问题
人工智能/第六阶段:机器学习-线性分类/SVM支持向量机算法 3406楼
WEB前端全系列/第二阶段:JavaScript编程模块/面向对象编程 3407楼
Python 全系列/第二阶段:Python 深入与提高/坦克大战 3408楼
Python 全系列/第二阶段:Python 深入与提高/文件处理 3409楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 3410楼
WEB前端全系列/第十一阶段:前端工程化/Webpack 3411楼

package com.itbaizhan;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;

/**
 * blob类型操作测试类
 */
public class BlobTest {
    /**
     * 向Movie表中插入数据
     */
    public void insertMovie(String moviename, InputStream is){
        Connection connection = null;
        PreparedStatement ps = null;

        try{
            //获取连接
            connection = jdbcUtils.getConnection();
            //获取PreparedStatement对象
            ps = connection.prepareStatement("insert into movie values(default,?,?)");
            //绑定参数
            ps.setString(1,moviename);
            ps.setBlob(2,is);
            ps.executeUpdate();

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            jdbcUtils.closeResource(ps,connection);
        }

    }

    public static void main(String[] args) throws FileNotFoundException {
        BlobTest bt = new BlobTest();
        //创建读取文件的IO流
        InputStream is = new FileInputStream(new File("d:/1.jpg"));
        bt.insertMovie("战狼",is);
    }
}

image.png为什么我这样打出来会显示不了名字

JAVA 全系列/第三阶段:数据库编程/JDBC技术 3412楼
JAVA 全系列/第二十一阶段:分布式医疗云平台/基础功能搭建 3413楼
Python 全系列/第四阶段:函数式编程和核心特性/函数式编程核心(高阶函数、闭包等) 3414楼
Python 全系列/第一阶段:Python入门/编程基本概念 3415楼

爬取一次之后就不能爬取了,建议爬取的时候在请求头里增加cookie属性,

def text_bs4():
    url = "https://www.maoyan.com/films"
    headers = {'User-Agent': UserAgent().firefox,
               "Cookie": 'uuid_n_v=v1; uuid=8236EB905E8611EEB2C88F0E1D778D2976602F68457842108D4B5999AAA9AC1B; '
                         '_csrf=95caf440d93adc2cf97b85c916a33ea5d547aa09c22e33e4109c0771222dc415; '
                         '_lx_utm=utm_source%3DBaidu%26utm_medium%3Dorganic; '
                         '_lxsdk_cuid=18adf587d66c8-037b0eb95fbfca-26031e51-1bcab9-18adf587d66c8; '
                         '_lxsdk=8236EB905E8611EEB2C88F0E1D778D2976602F68457842108D4B5999AAA9AC1B; '
                         'Hm_lvt_703e94591e87be68cc8da0da7cbd0be2=1695964233; '
                         'Hm_lpvt_703e94591e87be68cc8da0da7cbd0be2=1695965039; '
                         '__mta=142327309.1695964233411.1695964233411.1695965039712.2; '
                         '_lxsdk_s=18adf587d67-d26-b7b-f21%7C%7C4'}
    resp = requests.get(url, headers=headers)

    soup = BeautifulSoup(resp.text, 'lxml')
    names = [div.text.strip('\n') for div in soup.select("div.channel-detail.movie-item-title")]
    score = [div.text for div in soup.select("div.channel-detail.channel-detail-orange")]
    with open('猫眼bs4.txt', 'w', encoding='utf-8') as f:
        for n, s in zip(names, score):
            print(n, s ,file=f)


Python 全系列/第十五阶段:Python 爬虫开发/爬虫基础 3416楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO流技术 3417楼

老师这节课的代码原封不动的照抄下来了,
虽然实现了一模一样的功能,但是具体的逻辑没理解 真没听懂

又不想傻傻的不动脑筋 老师敲一行就跟一行 ,这样项目经验基本为0 
 
 所以换了一个方法 用之前课堂老师再flask第106节课讲的知识点
 关于SQLAlchemy数据分页的 讲解
 
   # #换一个之前falsk课学过能理解的方法 来
        username=request.args.get('username')
        pagenum=request.args.get('pagenum','1')       # 当数据没有传递的时候 默认值是1   页码
        pagesize=request.args.get('pagesize','2')     #当这个参数没有传递的时候 默认值是2 对应的每页显示的数据
        if not pagenum.isdigit():  #当用户传递参数 传入的不是数字 是乱七八糟的字符的时候 直接给干掉!
            return {"status":400,"msg":"页码必须是数字!",}
        if not pagesize.isdigit():
            return {"status":400,"msg":"每页显示的数量必须是数字!",}
        pagestart=int(pagesize)*(int(pagenum)-1)         #切片起始点  对应的是课堂老师当初分析数据分页的逻辑
        page_end=int(pagesize)*int(pagenum)              #切片终点
        '''页码是1 分页显示的数据量是2   就是0到1两条数据 。 页码是2 分页显示的数据量是2 就是显示 2和3这2条数据  往后类推'''
        #查询数据 
        user_list=User.query.filter(User.username.like(f'%{username}%')).slice(pagestart,page_end).all()
        data={
            "total":int(pagenum), #发给前端还是数字吧   免得到时候再vue里面用的时候或许还要转换一下
            "page_num":int(pagesize),  
            "data":[]
        }
        for i in user_list:
            data['data'].append(i.to_dict())
        return {"status":200,"msg":"数据查询成功","data":data}


Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 3418楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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