face_alignment报错 AttributeError: _2D 或 AttributeError: _3D 解决办法(简单)

文章讲述了在使用face_alignment库时遇到的AttributeError,原因是由于版本不匹配导致的_LandmarksType._2D属性不存在。解决方案包括升级或降级包版本,或直接修改源代码以适应现有版本的LandmarksType属性。
摘要由CSDN通过智能技术生成

当我们在需要使用face_alignment的工程里可能会出现以下错误:

    self.model = face_alignment.FaceAlignment(face_alignment.LandmarksType._2D, flip_input=False, device=device)
AttributeError: _2D

原因分析:

运行python,按照如下输入命令:

>python #我是从终端直接进入的python,大家也可以新建一个python文件输入下列命令并运行。
Python 3.9.18 (main, Sep 11 2023, 14:09:26) [MSC v.1916 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import face_alignment
>>> print(dir(face_alignment.LandmarksType))

发现只有’THREE_D’, ‘TWO_D’, ‘TW0_HALF_D’。
说明这个类里压根就没有_2D这个属性,应该是版本没对上。

>>> print(dir(face_alignment.LandmarksType))
['THREE_D', 'TWO_D', 'TWO_HALF_D', '__class__', '__doc__', '__members__', '__module__']

解决方案:

要么把这些python包的版本装对。(比下面的方法复杂,我认为没有必要)
要么依据报错信息直接改那个py文件,找到对应的代码位置,我把:

return face_alignment.FaceAlignment(face_alignment.LandmarksType._2D, device=dev)

修改成上面目前所拥有的类型,如2D的话按照如下修改:

return face_alignment.FaceAlignment(face_alignment.LandmarksType.TWO_D, device=dev)

如果是_3D只要改成THREE_D即可。

  • 26
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
非常抱歉,我的前一个回答有误。在python-docx 0.8.10及更高版本中,`_TableStyle`对象没有`table`属性,因此在示例代码中会出现该错误。 以下是更新的代码片段,其中使用了`_apply_to()`方法来应用样式: ```python from docx import Document from docx.enum.table import WD_TABLE_ALIGNMENT from docx.oxml.ns import nsdecls from docx.oxml import parse_xml from docx.shared import RGBColor def create_custom_table_style(document): # 创建一个名为"Custom Table"的表格样式 table_style = document.styles.add_style('Custom Table', base_style='Table Grid') # 指定第一行的底纹颜色为红色 shading_color = RGBColor(255, 0, 0) table_style.paragraph_format.space_after = 0 table_style.paragraph_format.space_before = 0 table_style.font.size = 12 table_style.font.name = 'Calibri' table_style._apply_to['table'] = True table_style._apply_to['tr'] = True table_style._apply_to['tc'] = True table_style._element.rPr = parse_xml( '<w:rPr ' + nsdecls('w') + '><w:color w:val="auto"/><w:sz w:val="20"/></w:rPr>' ) table_style._element.tblPr = parse_xml( '<w:tblPr ' + nsdecls('w') + '><w:tblW w:w="0" w:type="auto"/><w:tblBorders><w:top w:val="single" w:sz="4" w:space="0" w:color="auto"/><w:left w:val="single" w:sz="4" w:space="0" w:color="auto"/><w:bottom w:val="single" w:sz="4" w:space="0" w:color="auto"/><w:right w:val="single" w:sz="4" w:space="0" w:color="auto"/></w:tblBorders><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar><w:tblLook w:val="04A0"/></w:tblPr>' ) for row in table_style.iter_tr(): if row.index == 0: row._element.clear_content() row._element.append(parse_xml( f'<w:trPr {nsdecls("w")}><w:shd w:val="clear" w:color="auto" w:fill="{shading_color.rgb}" w:themeFill="text1"/><w:tblHeader/></w:trPr>' )) return table_style document = Document() custom_table_style = create_custom_table_style(document) # 创建一个新表格,并将自定义样式应用到表格中 table = document.add_table(rows=3, cols=3, style=custom_table_style) for row in table.rows: for cell in row.cells: cell.text = 'Test' document.save('test.docx') ``` 在上面的更新的代码中,我们使用了`_apply_to()`方法来告诉样式应该应用到哪些元素上。`True`值表示应用到该元素上,而`False`值表示不应用到该元素上。我们将`_apply_to['table']`设置为`True`,以便将样式应用到表格上。 最后,我们使用`document.add_table()`方法创建一个新表格,并将自定义样式应用到表格中。在这个示例中,我们创建了一个3x3的表格,其中第一行的底纹为红色,其他行没有底纹。 你可以将此代码片段中的自定义样式保存到文档中,以便在其他地方使用。例如,你可以将`create_custom_table_style()`函数定义为一个独立的模块,并在需要的地方导入它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值