'numpy.float64' object has no attribute 'translate' Inserting value to Mysql in Python

前端 未结 4 780
庸人自扰
庸人自扰 2021-02-14 15:00
import dataset
db = dataset.connect(....)
table = db[...]

When I try to insert some value into Mysql table, this error occurred.

Sample Value

4条回答
  •  南旧
    南旧 (楼主)
    2021-02-14 15:31

    Your library tries to format the provided arguments to a format MySQL will understand. To do so, it checks the type of each argument, to determine how the input should be formatted.

    However, since your lib doesn't knows numpy.float64, it fallbacks to a default encoder, which happens to be one for strings (unicode). Here is the relevent piece of code.

    def escape_item(val, charset, mapping=None):
        if mapping is None:
            mapping = encoders
        encoder = mapping.get(type(val))
    
        # Fallback to default when no encoder found
        if not encoder:
            try:
                encoder = mapping[text_type]
            except KeyError:
                raise TypeError("no default type converter defined")
    
        if encoder in (escape_dict, escape_sequence):
            val = encoder(val, charset, mapping)
        else:
            val = encoder(val, mapping)
        return val
    

    This encoder, assuming the input is indeed a string, tries to call the translate() method on this string. But, since this method isn't defined for float64, you get this error.

    You should try to convert your float64 to a regular float.

    Or, you can create your own encoder, and add it in the encoders dict used as the default mapping of python types to encoder. If you're going to use a lot this lib with float64, it may be worth doing.

提交回复
热议问题