百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python开发 常见异常和解决办法 python程序出现异常会执行哪个语句

liuian 2024-12-27 15:16 43 浏览

1.sqlalchemy创建外键关系报错property of that name exists on mapper

SQLAlchemy是Python编程语言下的一款开源软件,提供了SQL工具包及对象关系映射(ORM)工具,使得在Python中操作MySQL更加简单。在给两个表创建外键关系时可能会报错:

sqlalchemy.exc.ArgumentError: Error creating backref 'xxx' on relationship 'xxx.xxx': property of that name exists on mapper 'mapped class xxx->xxx'
1

两个数据模型如下:

class Website(Base):
    __tablename__ = 'website'
    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String(10), nullable=False)
    link = Column(String(40), nullable=False)

    orders = relationship('Order', backref='website')

class Order(Base):
    __tablename__ = 'order'
    id = Column(String(50), primary_key=True)
    desc = Column(Text, nullable=False)
    link = Column(String(80), nullable=False)
    contact = Column(String(30))
    category = Column(String(15))
    is_valid = Column(Boolean, nullable=False)
    add_time = Column(DateTime, default=datetime.now)
    website = Column(Integer, ForeignKey('website.id'), nullable=False)
    is_deleted = Column(Boolean, default=False)
12345678910111213141516171819

其中一个order对于各website,一个website可以对应多个order,在Website模型中定义关系时,backref为website,这与Order中本来的字段website重复而冲突,可以将该字段改名如wid,也可以将backref换名即可。

2.openpyxl保存数据报错openpyxl.utils.exceptions.IllegalCharacterError

在使用openpyxl保存数据时报错如下:

raise IllegalCharacterError
openpyxl.utils.exceptions.IllegalCharacterError
12

这是因为要保存的数据中存在一些openpyxl认为是非法字符的字符串,需要进行替换,直接使用其提供的ILLEGAL_CHARACTERS_RE进行转换即可,如下:

from openpyxl import Workbook
from openpyxl.cell.cell import ILLEGAL_CHARACTERS_RE

content = ILLEGAL_CHARACTERS_RE.sub(r'', content)
ws.cell(ridx, cidx).value = content
12345

此时即可正常保存数据。

3.使用sqlalchemy保存字符串到MySQL中时报错Incorrect string value: ‘\xF0…’ for column ‘desc’ at row 1

在使用sqlalchemy保存字符串数据到MySQL中会报错:

raise errors.get_exception(packet)
mysql.connector.errors.DatabaseError: 1366 (HY000): Incorrect string value: '\xF0\x9F\x91\x89\xCF\x84...' for column 'desc' at row 1
12

这是因为特殊字符\xF0\x9F\x91\x89\xCF\x84...导致的,实际上这是表情字符,即Emoji对应的字符,但是因为MySQL一般的字符集是utf8,因此Emoji表情或者某些特殊字符是4个字节,而Mysql的utf8编码最多3个字节,所以数据插不进去。

解决方法有两种:

  • 修改数据库的默认字符集编码
    修改为MySQL支持Emoji的字符集utf8mb4,具体如下:
    (1)在MySQL的安装目录中找到配置文件my.ini,修改如下:[client] default-character-set = utf8mb4 [mysql] default-character-set = utf8mb4 [mysqld] character-set-client-handshake = FALSE character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci init_connect='SET NAMES utf8mb4' 123456789(2)并通过命令修改当前数据库和表的编码:ALTER DATABASE database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; alter table table_name convert to character set utf8mb4 collate utf8mb4_bin; 123(3)配置完成后重新启动MYSQL服务即可
  • 替换Emoji字符串
    通过正则表达式匹配字符串中的Emoji字符并替换,即可不用修改数据库的字符集也能正常插入。具体如下:import re # Emoji字符正则表达式 try: # Wide UCS-4 build emoji_regex = re.compile(u'[' u'\U0001F300-\U0001F64F' u'\U0001F680-\U0001F6FF' u'\u2600-\u2B55]+', re.UNICODE) except re.error: # Narrow UCS-2 build emoji_regex = re.compile(u'(' u'\ud83c[\udf00-\udfff]|' u'\ud83d[\udc00-\ude4f\ude80-\udeff]|' u'[\u2600-\u2B55])+', re.UNICODE) desc = emoji_regex.sub('[Emoji]', desc_str) # desc为可能包含表情的字符串 1234567891011121314151617181920

这两种方法中,个人建议使用第二种方法,只是对字符串进行处理,无需修改数据库的相关配置。

4.使用sqlalchemy将字符串保存到MySQL报错AttributeError: ‘MySQLConverter’ object has no attribute ‘__elementunicoderesult_to_mysql’

在使用requests库爬取到网页并使用lxml.etree包进行解析网页后,通过xpath获取到指定的元素和文本,并通过sqlalchemy将文本保存到数据库中时报错:

raise errors.ProgrammingError(
sqlalchemy.exc.ProgrammingError: (raised as a result of Query-invoked autoflush; consider using a session.no_autoflush block if this flush is occurring prematurely)
(mysql.connector.errors.ProgrammingError) Failed processing pyformat-parameters; Python '_elementunicoderesult' cannot be converted to a MySQL type
123

这是因为通过lxml.etree获取到的字符串可能是_elementunicoderesult,这是Python中字符串的一种,danssqlalchemy并未蹄冻将该类型变量转化为SQL对象的方法,因此需要强制转换为str类型,再进行数据保存,如下:

link = str(order.xpath('./div[1]/div[2]/a/@href')[0])
#...
order = OrderModel(id=yid, desc=desc, link=link, contact=contact, category='', pub_time=None, is_valid=is_valid, is_delete=False if is_valid else True)
order.website = website
session.add(order)
session.commit()

本文的文字及图片来源于网络加上自己的想法,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。

相关推荐

win11系统体验版(win10体验win11)

要体验最新的Win11系统,首先需要检查电脑是否符合Win11的硬件要求,例如处理器、存储、显卡等。如果符合要求,可以前往微软官网下载Win11系统的ISO镜像文件,然后将其写入U盘或DVD光盘。接着...

可以免费主题的软件下载(有什么可以免费弄主题的软件)
可以免费主题的软件下载(有什么可以免费弄主题的软件)

步骤如下:1.我们首先打开vivo手机,在vivo手机自带的APP找到I主题,然后打开I主题,会在打开的时候看到精选里面包含了:主题,字体,铃声,息屏和动态壁纸。2.我们在我们在此页面的右上角找到一个放大镜的标识,点击,然后在弹出的页面输...

2025-11-11 06:55 liuian

怎么设置路由器ip(怎么设置路由器IP地址成2网段)

设置Wifi路由器的IP地址需要登录路由器管理界面。一般来说,路由器的管理地址为192.168.1.1或192.168.0.1,具体地址可以在路由器说明书或者设备背面上找到。下面是具体操作步骤:1....

ie8浏览器是什么意思(ie8浏览器是什么样子的)
ie8浏览器是什么意思(ie8浏览器是什么样子的)

IE8浏览器发布于2009年3月,携手Windows7,安全性得到非常大的增强,可以下载超过4G的文件,也是微软第一个64位版浏览器。微软的IE浏览器,版本是8——11原名叫MicrosoftInternetExplorer是微软...

2025-11-11 05:55 liuian

怎么登陆qq邮箱(163邮箱怎么登陆qq邮箱)
怎么登陆qq邮箱(163邮箱怎么登陆qq邮箱)

1.以苹果iPhone12、iOS15.3为例。选qq邮箱在苹果手机邮件应用页,点击“qq邮箱”选项。2.点下一步输入帐号密码,点击“下一步”。3.验证登录验证完成后,进行登录即可。...

2025-11-11 05:05 liuian

win7纯净旗舰版下载(win7 纯净版)

下载win7纯净版方法如下:在电脑上打开搜索软件,在搜索框里搜寻微软官方网址,打开官网后,第一条进入找到系统版本选择WIN7纯净版,点击立即下载将下载地址设置为本地C盘,下载进度100%后就下载成功...

大白菜重装系统详细步骤(大白菜重装系统步骤和详细教程)

u盘大白菜重装系统的步骤~~1、首先将u盘制作成大白菜u盘启动盘,重启电脑等待出现开机画面按下启动快捷键,选择u盘启动进入到大白菜主菜单,选取“【02】运行大白菜Win8PE装机维护版(新机器)”选项...

office plus官方网站(officeplus官方网站公众号)

1、选中你想要添加翻页的ppt页面,我们这里以这个ppt的第二个页面为例。;2、在页面上方的菜单栏找到“切换'这个选项,选择”切换“中的”页面卷曲“动画效果。;3、设置完毕后,如果你想要选择翻...

u盘制作启动盘后如何恢复原来的样子

可以通过U盘启动盘制作工具的恢复普通盘功能将制作了启动盘的U盘恢复为一个普通U盘,这类制作工具核心相同,都可以实现删除隐藏启动文件的功能,下面以电脑店启动盘制作工具为例:1、将U盘插入电脑,然后运行电...

xp系统安装版免费版华为版(windows xp 安装版)

1、点击主界面中的【设置】进入到设置界面,然后向下滑动即可找到【开发者选项】,点击进入。2、点击【开发者选项】右边的按钮打开此功能,然后在弹出的提示框中选择【确定】。值得注意的是,启用这个功能可能会导...

手机网页自动翻译插件(手机网页自动翻译插件免费版)

找到了吗你好;苹果自带浏览器添加书签按也是要占用手机内存的,自带浏览器的安装包太大,会影响手机运行的,你可以下载一个QQ浏览器。它的安装包很小,不影响手机运行,它使用的极速内核,有着神速一般的浏览体验...

0x0000007e(0X0000007E)

错误分析系统进程会生成错误,但是Windows错误处理器无法捕获它。蓝屏无法正常进入系统或无法正常运行,这通常是由软件或硬件故障引起的。原因有很多,原因很复杂,例如系统文件损坏,病毒感染,后台自启动程...

联想笔记本电脑键盘介绍图(联想笔记本电脑键盘功能基础知识解释图)

ESC键:另一个名称叫做逃逸键,在填用户名或者打错的时候使用ESC键,可以清理所有的框内内容,较为便利。Tab键:Tab键是Table(表格)的简写,所有也被人们称作表格键,在文本文档时,按这个键,光...

wifi万能钥匙正版下载(wifi万能钥匙下载最新版)

1、首先打开手机应用中心下载安装wifi万能钥匙。;;2、安装完成后,点击打开wifi万能钥匙即可使用。;具体使用...

好看电脑桌面壁纸高清(好看电脑桌面壁纸高清搞怪)

首先,在桌面点击右键,然后进入属性,然后进入显示,然后上面写着屏幕分辨率,再按照分辨率下载壁纸  以下为调整电脑桌面清晰度步骤:  1,启动电脑,来到桌面,在空白处,单击鼠标右键,去打开桌面右键菜单...