python使用ctypes调用c++函数时怎样传入IPlImage型的数据? 40C

python 代码

import ctypes
import numpy as np
import cv2
from Face_Alignment import warp_im, coord5point, resizeimage
import time
from numpy.ctypeslib import ndpointer
start = time.time()
so = ctypes.cdll.LoadLibrary
lib = so("./build/liblandmark.so")
class StructPointer(ctypes.Structure):
    _fields_ = [("x",ctypes.c_double),
                ("y",ctypes.c_double)]
lib.test.argtypes = [ctypes.c_int,ndpointer(ctypes.c_uint8)]
path = "/Huang/images/3.jpeg"
img = cv2.imread(path)
imge_1 = cv2.cv.LoadImage(path, cv2.cv.CV_LOAD_IMAGE_COLOR)

point = lib.landmark(1,imge_1)


c++代码:

extern "C"
{
seeta::StructPointer landmark(int argc, IplImage* imge)
{        
  seeta::FaceDetection detector("./build/seeta_fd_frontal_v1.0.bin");
  detector.SetMinFaceSize(40);
  detector.SetScoreThresh(2.f);
  detector.SetImagePyramidScaleFactor(0.8f);
  detector.SetWindowStep(4, 4);
  seeta::FaceAlignment point_detector((MODEL_DIR + "seeta_fa_v1.1.bin").c_str());

  IplImage *img_grayscale = NULL;
  cvCvtColor(imge, img_grayscale, CV_BGR2GRAY);//把从python中获得的iplimage参数灰度化传给img_grayscale

  IplImage *img_color = imge;


运行结果:Traceback (most recent call last):
File "test.py", line 27, in
point = lib.landmark(1,imge_1)
ctypes.ArgumentError: argument 2: : Don't know how to convert parameter 2
这里python中的Iplimage 参数应该如何通过ctypes传入c++中。我的实际问题是怎样把在python中获得的np.array传入c++函数中并赋值给Iplimage型的参数

1个回答

你传id(imge_1)试试 id()取地址的的,

xingjianfengaa
xingjianfengaa 还有其实你的so里函数应该用void*imge,否则像碰到这种跨语言的调用就麻烦
接近 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
python使用ctypes调用c++函数时怎样传入IPlImage型的数据?

python 代码 ``` import ctypes import numpy as np import cv2 from Face_Alignment import warp_im, coord5point, resizeimage import time from numpy.ctypeslib import ndpointer start = time.time() so = ctypes.cdll.LoadLibrary lib = so("./build/liblandmark.so") class StructPointer(ctypes.Structure): _fields_ = [("x",ctypes.c_double), ("y",ctypes.c_double)] lib.test.argtypes = [ctypes.c_int,ndpointer(ctypes.c_uint8)] path = "/Huang/images/3.jpeg" img = cv2.imread(path) imge_1 = cv2.cv.LoadImage(path, cv2.cv.CV_LOAD_IMAGE_COLOR) point = lib.landmark(1,imge_1) ``` c++代码: ``` extern "C" { seeta::StructPointer landmark(int argc, IplImage* imge) { seeta::FaceDetection detector("./build/seeta_fd_frontal_v1.0.bin"); detector.SetMinFaceSize(40); detector.SetScoreThresh(2.f); detector.SetImagePyramidScaleFactor(0.8f); detector.SetWindowStep(4, 4); seeta::FaceAlignment point_detector((MODEL_DIR + "seeta_fa_v1.1.bin").c_str()); IplImage *img_grayscale = NULL; cvCvtColor(imge, img_grayscale, CV_BGR2GRAY);//把从python中获得的iplimage参数灰度化传给img_grayscale IplImage *img_color = imge; ``` 运行结果:Traceback (most recent call last): File "test.py", line 27, in <module> point = lib.landmark(1,imge_1) ctypes.ArgumentError: argument 2: <type 'exceptions.TypeError'>: Don't know how to convert parameter 2 这里python中的Iplimage 参数应该如何通过ctypes传入c++中。我的实际问题是怎样把在python中获得的np.array传入c++函数中并赋值给Iplimage型的参数

Python ctypes 中回调函数设置

我在python中想调用dll库的函数,但是这个dll库的函数参数需要设置一个回调函数指针,如下 void setCallBack(void(*)(Data &a)) Data is C struct, declare as below typedef struct { int index, .... }Data 我在python中调用代码如下: mydll = cdll.LoadLibrary("XXX.dll") callback_type = CFUNCTYPE(None, POINTER(Data)) callback = callback_type(Data) mydll.setCallBack(callback) def dataResponse(data): print data.index class Data(ctypes.Structure): _fields_ = [("index", c_int)] 调用时发生"WindowsError: [Error -1073741795] Windows Error 0xC000001D"错误, 请大家帮忙看一下如何设置回调函数,感觉如何参数类型是C++引用的话,POINTER好像是不对的。

在python中用ctypes模块调用Windows API的问题

用python做一个windows平台的工具,纯python缺乏接口,因此想用ctypes模块调用Windows API来实现,碰到了下列问题: 用python封装Windows 中的SystemTimeToFileTime,调用过程中提示参数不对。 Windows API 原型 BOOL WINAPI SystemTimeToFileTime( __in const SYSTEMTIME* lpSystemTime, __out LPFILETIME lpFileTime ); python 封装代码: from ctypes import * from ctypes.wintyps import * #封装 SYSTEMTIME 类型 class SYSTEMTIME(Structure): __fields__ = [("Year", WORD), ("Month", WORD), ("DayOfWeek", WORD), ("Day", WORD), ("Hour", WORD), ("Min", WORD), ("Sec", WORD), ("MillSec", WORD)] # FILETIME class FILETIME(Structure): __fields__ = [("dwLowDateTime", DWORD), ("dwHighDateTime", DWORD)] # 封装SystemTimeToFileTime proto_systm2filetm = WINFUNCTYPE(BOOL, POINTER(SYSTEMTIME), POINTER(FILETIME)) paramflags = (1, "systime", None), (2, "filetime", None) SystemTimeToFileTime = proto_systm2filetm(("SystemTimeToFileTime", windll.kernel32), paramflags) #测试 atime = FILETIME() atime.dwLowDateTime = 0 atime.dwHighDateTime = 100 systm = SYSTEMTIME() systm.Year = 2015 systm.Month = 1 systm.Day = 5 systm.DayOfWeek = 1 systm.Hour = 1 systm.Min = 17 systm.Sec = 0 print SystemTimeToFileTime(systime = pointer(systm), filetime=pointer(atime)) print "error:%d" % GetLastError() #结果: 提示 print SystemTimeToFileTime(systime = pointer(systm), filetime=pointer(atime)) TypeError: call takes exactly 1 arguments (2 given) 疑问:SystemTimeToFileTime明明声明了2个参数,为啥提示只接受一个参数? 尝试修改,将paramflags该成: paramflags = (1, "systime", None), (1, "filetime", None) 这下没有提示参数个数不对了,但是函数执行返回FALSE, GetLastError == 87(参数不正确)。 请各位帮忙把把脉,API中的 IN, OUT参数,用ctypes应该如何包装? 使用时如何传实参? 万分感谢!

python调用c++函数时怎样传入const char*型的参数?

python代码: ``` ``` import ctypes so = ctypes.cdll.LoadLibrary lib = so("./build/liblandmark.so") path = "/face/360p/1.jpg" lib.landmark(1,ctypes.c_char_p(path)) ``` ``` c++代码: #include <cstdint> #include <fstream> #include <iostream> #include <string> #include "cv.h" #include "highgui.h" #include "face_detection.h" #include "face_alignment.h" #ifdef _WIN32 std::string DATA_DIR = "../../data/"; std::string MODEL_DIR = "../../model/"; #else std::string DATA_DIR = "./data/"; std::string MODEL_DIR = "./model/"; #endif extern "C" { seeta::FacialLandmark landmark(int argc, char*argv) { // Initialize face detection model seeta::FaceDetection detector("./build/seeta_fd_frontal_v1.0.bin"); detector.SetMinFaceSize(40); detector.SetScoreThresh(2.f); detector.SetImagePyramidScaleFactor(0.8f); detector.SetWindowStep(4, 4); // Initialize face alignment model seeta::FaceAlignment point_detector((MODEL_DIR + "seeta_fa_v1.1.bin").c_str()); //load image const char* img_path = argv; IplImage *img_grayscale = NULL; img_grayscale = cvLoadImage(img_path, 0); IplImage *img_color = cvLoadImage(img_path,1); int pts_num = 5; int im_width = img_grayscale->width; int im_height = img_grayscale->height; ``` ``` 这里的 const char* img_path 传不进去,应该怎么办。尝试过static_cast强制转换类型,将传入c++的char*类型的数据通过static_cast转换为const char* 但还是不行

python3 ctypes 的 结构体定义中,怎么引用自身?

我这么使用时提示说“找不到Sentence_link” ``` class Sentence_link(ctypes.Structure): _fields_= [("para_idx", ctypes.c_ulong), ("sent_idx", ctypes.c_ulong),("sent_init",ctypes.c_int),("msg_buff",ctypes.c_char_p), ("next",ctypes.POINTER(Sentence_link))] ``` ``` _fields_= [("para_idx", ctypes.c_ulong), ("sent_idx", ctypes.c_ulong),("sent_init",ctypes.c_int),("msg_buff",ctypes.c_char_p), ("next",ctypes.POINTER(Sentence_link))] NameError: name 'Sentence_link' is not defined ``` 请问该如何引用自身?

python3使用ctypes有些c类型没有怎么办?

被实习作业折磨到摸不着头脑 菜狗一只,平常总是靠度娘解决问题,但这次真的搜不到了(╥╯^╰╥) 实在不想用C++......而且已经丢了很久了...... 学校实习任务开发指纹仪的相关软件,调用dll函数。 问题1: dll函数:HANDLE_stdcall sensorOpen(int index) 这个类型是句柄HANDLE,其返回值需要用到,但是Python没有直接HANDLE,我用int接收暂没出现问题,怕之后会遇到先问一个。 问题2: dll函数:int_stdcall sensorCapture(HANDLE handle,unsigned char* imageBuffer, int imageBufferSize)//获取图像 handle就是上面那个,unsigned char* 文档解释是接收的图像即是输入的参数也会输出,后续指纹算法需要,ctypes也没有,怎么实现? 我目前使用imageBuffer = create_string_buffer(所需空间大小),但是没有采集到图像(我检验了该函数返回值,为0,即无图像) 我也试过了create_unicode_buffer,结果也一样。到底是使用方法问题还是其他导致我真的没采集到图像 问题3:(虽然前面的还没解决但先问下)(准确的说目前卡在这里) dll函数:HANDLE stdcall BIOKEY_INIT(int License, WORD *isize, BYTE*Params, BYTE *Buffer, intImageFlag) 问题出在isize:文档描述:[in] 传入一个无符号双字节长度为22 的数组,且 isize[0]和isize[20]为传入图像宽度,isize[1]和 isize[21]为传入图像高度 这isize怎么提前定义? 我尝试使用isize = bytearray()处理,但是毕竟是双字节,光是宽度就有300多,但byte要在0-255之间,而且还不确定都是数字(我试过定义为整型数组,报错don't konw how to convert parameter 2)。作为指纹图像,虽然有函数可以修改采集图像的大小,但是太小了的话数据的完整性和可使用性就大打折扣。所以这个双字节咋整啊 问题4: 有些函数传入参数为int*,咋整......我先去看看ctypes的文档,但是我记得上次看的时候好像没有针对这种指针的...直接使用c_char_p吗?(目前没法验证这个方法是否可行,因为前面就走不通。。。) 总之目前就这些了,实习作业周三开始检查希望会的大佬帮帮我!谢谢啦! 我先滚去看文档了。。。

python的ctypes加载遇到相互依赖的库如何处理?

现在又两个库函数a.so和b.so,现在想加载a库实现a库里的ar方法,加载a库的时候报错提示OSError: /usr/lib/a.so: undefined symbol:bf,经过核实bf在b库里于是加载b库,发现b库也报错OSError: /usr/lib/b.so: undefined symbol:af,进经过了解两个库相互依赖,导致ctyps两个库都无法加载,从而不能实现a库方法的调用。想问下大家: 1.这类问题如何处理? 2.有没有指定加载库里的函数的方法

如何从Python调用Go函数

<div class="post-text" itemprop="text"> <p>I am trying to call go lang function from python when I call my python program I am seeing the following error. I am referring to the <a href="https://medium.com/learning-the-go-programming-language/calling-go-functions-from-other-languages-4c7d8bcc69bf" rel="nofollow noreferrer">Go to pythn</a> link. </p> <p><a href="https://i.stack.imgur.com/dFZr3.png" rel="nofollow noreferrer"><img src="https://i.stack.imgur.com/dFZr3.png" alt="error"></a></p> <p>Python Program</p> <pre><code> from ctypes import * def call_go_function(): lib = cdll.LoadLibrary("./awesome.so") lib.Add.argtypes = [c_longlong, c_longlong] print( lib.Add(12,99)) call_go_function() </code></pre> <p>Go Program</p> <pre><code>package main import "C" import ( "sync" ) var count int var mtx sync.Mutex //export Add func Add(a, b int) int { return a + b } func main() {} </code></pre> </div>

AIX系统Python缺少_ctypes模块

AIX6.1,自带的Python2.7.5,试图在上面安装setuptools插件,报缺少_ctypes模块, ![图片说明](https://img-ask.csdn.net/upload/201708/03/1501740395_976629.png) 检查了Linux系统和Windows,在Python的lib库里面有_ctypes.so和_ctypes_test.so两个库,但AIX下只有test一个。 ![AIX](https://img-ask.csdn.net/upload/201708/03/1501740669_470043.png)AIX系统 ; ![Ubuntu](https://img-ask.csdn.net/upload/201708/03/1501740697_443887.png)Ubuntu系统 试过重装Python-libs这个RPM包,但报包冲突。升级Python也是诸多系统库缺少或者安装冲突。 求助各位大神,该如何破,缺少_ctypes模块,不仅setuptools,还有pip等组件都装不了。

我尝试在python中调用DLL,但我找不到函数,请帮助我

正如标题所说,我试图使用python调用一个DLL,但是遇到了问题 ## # 请帮助我,非常感谢**** **python**: ``` dllPath = r"D:\fomas-Com" os.chdir(dllPath) dllName = dllPath + "\Imccor01.dll" dll = cdll.LoadLibrary(name=dllName) dll.RainflowAnalysis.AddResidue() ``` **发生的错误:** ``` Traceback (most recent call last): File "D:/111/Test/dlltest.py", line 17, in <module> dll.DFile.Open() File "D:\111\Anaconda3\envs\env_name\lib\ctypes\__init__.py", line 361, in __getattr__ func = self.__getitem__(name) File "D:\111\Anaconda3\envs\env_name\lib\ctypes\__init__.py", line 366, in __getitem__ func = self._FuncPtr((name_or_ordinal, self)) AttributeError: function 'DFile' not found ``` **在VB中成功调用:** ``` # 工程中加载了Dll Sub ProcessFile(SrcFileName As String) On Error GoTo FinalCleanUp Call ClearAllMsg Dim SrcFile As New DFile, C As DChannel, TotalNum As Integer SrcFile.Open SrcFileName, cdmFileRead For i = 1 To SrcFile.Count Form1.DataName.Text = SrcFile.GetObjectName(i) ```

python调用dll的释放问题

小弟用python 写了个调用SiInterface.dll的adaptor.exe 这里有调用win32api.FreeLibrary()释放dll了, 运行该adaptor.exe后,做完一个交易后,其他程序调用这个dll做交易就会加载不到这个dll,请问是我没释放成功SiIterface.dll 还是adaptor.exe打开运行后,他就一直占用着SiInterface.dll 因为在使用adaptor.exe做完一个交易后关闭该exe,再使用别的程序调用SiInterface.dll就是ok的,请教各位大神如何在不关闭adaptor.exe情况下 还能是别的程序能够访问该SiInterface.dll def call_mi_dll(sIn): dll = ctypes.WinDLL('SiInterface.dll') sIn += ' '*(512-len(sIn)) sOut = ' '*512 i=' '*1024 i=ctypes.c_char_p(i) sIn = ctypes.c_char_p(sIn) sOut = ctypes.c_char_p(sOut) print "calling: SiInterface.dll -> INIT" ret=dll.INIT(i) print "Init :"+str(ret) print "calling: SiInterface.dll -> BUSINESS_HANDLE" dll.BUSINESS_HANDLE(sIn, sOut) win32api.FreeLibrary(dll._handle) return sOut.value

python 调用C++ dll (该dll 依赖其他dll)

问题描述: C++中有两个类 bclass 和 nclass,其中nclass 里面的一个private变量就是bclass。 这两个类目前都被写成了动态库 libbclass.so 和 libnclass.so。 当我在Python中利用ctypes模块希望调用libnclass.so的时候,程序报错 OSError: libbclass.so: cannot open shared object file: No such file or directory 我的问题: 1、如何调用libnclass.so 2、如何在python中创建一个nclass类的实例,并调用该实例的方法add

python 调用DLL 动态库之后 怎么释放

各位大神,请问python 利用 ctypes调用DLL之后怎么释放啊

python ctypes 调用DLL,读取工业摄像机出错

用python ctypes 模块,调用厂家提供的c写的DLL,来读取工业摄像机,cameraInit(k = mylib.CameraInit(byref(cInfor), -1, -1, cameraHandle *p_p_i)) 成功,但 g=mylib.Cameraplay( camerahandle p_p_i) ,出错, 有谁有这方面的经验呀

Win10 64位,python3.5, 用ctypes调用DLL,读取摄像头,存为numpy数据格式.

Win10 64位,python3.5, 用ctypes调用MVCAMSDK_X64.DLL,读取mindvision的摄像头,生成jpg图像,存为numpy数据格式,求完整python代码。以下运行到Cameraplay出错,以下对应C的原形: typedef int CameraHandle; 原型: MVSDK_API CameraSdkStatus CameraSdkInit ( int iLanguageSel ); MVSDK_API CameraSdkStatus CameraInit ( tSdkCameraDevInfo* pCameraInfo, int emParamLoadMode, int emTeam, CameraHandle* pCameraHandle ); MVSDK_API CameraSdkStatus CameraPlay ( CameraHandle hCamera ); MVSDK_API CameraSdkStatus CameraEnumerateDevice ( tSdkCameraDevInfo *pDSCameraList, INT *piNums ); 以下为python 代码; from ctypes import * import numpy as np from ctypes.wintypes import * mylib=cdll.LoadLibrary('C:\Program Files (x86)\MindVision\SDK\X64\MVCAMSDK_X64.DLL') hand=HANDLE() i = c_int(1) t=c_int(-1) s=c_int(1) class tSdkCameraDevInfo(Structure): _fields_ = [('uVendorID', c_uint), ('uProductID', c_uint), ('acVendorName',c_char), ('acProductSeries',c_char), ('acProductName',c_char), ('acFriendlyName',c_char), ('acDevFileName',c_char), ('acFirmwareVersion',c_char), ('acSensorType',c_char), ('acPortType',c_char)] pi=pointer(i) ti=pointer(t) p_i=POINTER(c_int) p_p_i=p_i(i) pii=create_string_buffer(2) piii = create_unicode_buffer(2) cInfor=tSdkCameraDevInfo() l=mylib.CameraSdkInit(1) pp = create_unicode_buffer(4) j=mylib.CameraEnumerateDevice(byref(cInfor),pi) mylib.CameraInitEx.argtypes=(c_int,c_int,c_int) k = mylib.CameraInit(byref(cInfor), -1, -1, byref(hand)) g=mylib.Cameraplay(hand) ####这里出错了 print(l) print(j) print(k) print(hand)

为什么python使用ctypes无法加载qt生成的dll?

使用ctypes可以加载windows生成的dll,但是无法加载qt生成的dll,dll使用vs depends工具 查看,确定是已经以C语言风格导出了dll,但是ctypes加载qt生成的dll报错:找不到指定的 模块,不知道为什么? 开发环境: window7 x86 python3.4 qt5.5

python Ctypes 加载使用了C++amp的dll 失败

在使用python 的Ctypes调用 里面包含了C++ amp的dll的时候就会报这个错误[WinError 1114] 动态链接库(DLL)初始化例程失败。 但是如果去掉C++AMP的部分就不会报错了求解。

Python 使用ctypes的shell32 获取文件详细属性

import ctypes shell32 = ctypes.windll.LoadLibrary('shell32.dll') folderitems= 应该如何将文件路径转化为对象?'F:\\1.pptx' a = folderitems.ExtendedProperty("Title") print a

python 调用dll如何返回多个值

import scipy.io as scio import os import ctypes import datetime import numpy as np #读取dll文件 #这里的地址目录是HessianFilter.dll所在的文件夹 start = datetime.datetime.now() cur_path = os.path.dirname(r'C:\Users\Administrator\Desktop\code_and_data\code\HessianFilter\\') dll_path = os.path.join(cur_path,'HessianFilter.dll') print dll_path dll = ctypes.windll.LoadLibrary(dll_path) #读取mat文件,Mat文件所在的文件夹中读取 matPath = r'C:\Users\Administrator\Desktop\code_and_data\data\Nodule19664.mat' imgData = scio.loadmat(matPath) #从mat文件中我们取到了整个三维数组 imgDataArray = imgData['imagetest1'] #得到数组文件的参数:宽,高,层数 widthSrc,heightSrc,sliceNumSrc = imgDataArray.shape #声明一个三维的c_float类型的数组,用于存放mat数据,并将数据转化为c_float imgDataArray_p = (((ctypes.c_float*sliceNumSrc)*heightSrc)*widthSrc)() for i in range(widthSrc): for j in range(heightSrc): for k in range(sliceNumSrc): imgDataArray_p[i][j][k] = ctypes.c_float(imgDataArray[i][j][k]) imgDataP = ctypes.POINTER(ctypes.c_float)(imgDataArray_p) print '---------->' #需要再声明两个返回值 HessianDot = (ctypes.c_float*(widthSrc*heightSrc*sliceNumSrc))() HessianLine = (ctypes.c_float*(widthSrc*heightSrc*sliceNumSrc))() HessianDot_p = ctypes.POINTER(ctypes.c_float)(HessianDot) HessianLine_p = ctypes.POINTER(ctypes.c_float)(HessianLine) #定义一个常数 sigma = ctypes.c_float(8) #定义一个三维数组 imgSize = [widthSrc,heightSrc,sliceNumSrc] imageSize = (ctypes.c_float*len(imgSize))(*imgSize) #定义一个指向三维数组的指针 imageSizeP = ctypes.POINTER(ctypes.c_float)(imageSize) #这个就是调用dll中的函数了 dll.RunHessianMultiThread(ctypes.byref(imgDataArray_p),sigma,ctypes.byref(imageSizeP),ctypes.byref(HessianDot_p),ctypes.byref(HessianLine_p),4) print '--调用后-点数据--' print HessianDot_p print HessianDot_p[0:24] #print HessianDot_p.contents print '--调用后-线数据--' print HessianLine_p print HessianLine_p[0:24] #print HessianLine_p.contents print '<---------Over------------->\n\n' print datetime.datetime.now()-start

用ctypes向dll传入的数组,返回python后,其中的数据有时正确有时错误,怎么办?

运行环境: win10 + anaconda5.3 + jupyter python文件 ``` import numpy as np import pandas as pd mylib = ctypes.cdll.LoadLibrary('mydll.dll') C_fun = mylib.func_name C_fun.restypes = None C_fun.argtypes = pass_args_Struct, c_double*10 # pass_args_Struct 是继承ctypes.Structure定义的结构体,代码略 def generate_Struct(data, 其他参数略): # 生成 pass_args_Struct,代码略 # data是个DataFrame,用于接收下面myClass的data属性 class myClass(): # myclass有个data属性,data是一个DataFrame # 其他代码略 def func1(self, x): # 删除self.data的一列,再根据x参数重新添加这一列,代码略 struct_x = generate_Struct(self.data, 其他参数略) myArr = (c_double*10)() C_fun(struct_x, myArr) npArr = np.ctypeslib.as_array(myArr,(10,)) return pd.Series(npArr, _column_names) # _column_names 定义略 def func2(self): # 生成df,df是个只有一列值的DataFrame,代码略 return df.apply(lamba x: self.func1(x[0]), axis=1, result_type='expand')) # 其他代码略 ``` mydll.dll中的代码 ``` #define API extern "C" __declspec(dllexport) typedef pass_args_Struct { // 对应于python中pass_args_Struct,代码略 } API void func_name(pass_args_Struct* x, double arr[]) { // 对arr进行一些操作,代码略 } ``` 在jupyter中: 导入前述Python文件并生成 myObject=myClass() 之后, 执行ret1 = myObject.func1()没什么问题, 但是ret2 = myObject.func2()的结果则有时正确有时错误,错误的时候,ret2中会出现一些NaN值和错误的值。 之前把generate_Struct()定义成myclass的一个方法,连ret1也会出错; 之前的func1(self, x)中采用: ``` func1(self, x): # 其他代码略 myArr = np.ctypeslib.as_array(myArr,(10,)) # 左边不用新名而直接用myArr return pd.Series(myArr, _column_names) ``` 则ret1会频繁出错,基本上是对一次就错一次。 程序一直能运行,只是结果有时不正确。 请教各位大牛,正确的写法是什么样子的? ==================================================== =====2018年11月30日更新==================================== 我可能发现问题了: Python文件TestX.py(放在PYTHONPATH下): ``` import numpy as np from ctypes import Structure, c_double, c_int, POINTER class struct_args(Structure): _fields_ = [('data',POINTER(c_double*2)), ('rows',c_int)] class test(): def __init__(self): self.data = None def get_args_2C(self): arr = np.ascontiguousarray(self.data[['foo','bar']].values, dtype=np.float) rows = c_int(arr.shape[0]) return struct_args(arr.ctypes.data_as(POINTER(c_double*2)), rows) ``` 在jupyter中: ``` import TestX import pandas as pd import numpy as np mydata = pd.DataFrame(np.arange(1600).reshape(800,2),columns=['foo','bar']) # 行数不要太小 mytest = TestX.test() mytest.data = mydata args = mytest.get_args_2C() np.ctypeslib.as_array(args.data,(800,)) ``` 输出的值经常是错误的。 ==================================================== =====2018年12月3日更新==================================== 不知道为什么,但总算是不出错了: python文件: ``` from ctypes import Structure,POINTER,c_double def Struct_A(ctypes.Structure): _fields_ = [(), # 其他成员略 ('my_arr',POINTER(c_double)] # 这个地方用c_double*10后面也会出错 class myClass(): def makeStructA(self, 其他参数): arr = (c_double*10)() SA = Struct_A(……,arr) # 其他成员略 return SA def myMethod(self, 其他参数): SA = self.makeStructA(其他参数) # myCfun是dll中的函数,功能是利用SA中数据进行一些计算,然后把结果写入SA.my_arr,具体代码略 myCfun(SA) ret = pd.Series(np.ctypeslib.as_array(SA.my_arr,(10,)), _columns_name) ret['odd'] = 1 # 这里随便新加点什么就不会出错了 return ret ``` 以上代码如果没有ret['odd']=1那一行,则myObject.myMethod()返回的Series中都是错误的值(看着像是内存未初始化,比如-2.24934335e308之类),而随便给ret添加点什么内容,返回值就是正确的了。 但是在以下计算中仍然会出错,只是出错的频率变小了,而且多运行几次就会正确: ``` class myClass(): # 接上文 def myOptimize(self, arg_name, arg_range): ret = pd.DataFrame({arg_name:arg_range}) _optimize = lambda arg: self.myMethod(**{arg_name:arg[arg_name]}) return ret.join(ret.apply(_optimize, axis=1, result_type='expand')) ``` ===================================== =====2018年12月7日更新==================================== 又出错了!!!12月3日写的: ``` ret['odd'] = 1 # 这里随便新加点什么就不会出错了 ``` 那个函数确实不出错了,但是别的函数用同样的写法(先生成c_double*shape再传入dll在C中写入值)得到的ret无论添加行还是添加列,多运行几次总会出错(内存被清理)。 换一种写法: ``` 略 arr=np.zeros(shape) 略 # 然后传入arr.ctypes.data_as(POINTER(c_double*10)) ``` 目前暂时不出错了。 =====2018年12月13日更新==================================== 前面的写法有问题:用函数生成结构体(比如makeStructA)再传递给dll就会出错,直接将makeStuctA的代码放到myMethod中就不会出错。 另外,传递结构体时用byref就不会出错了,在dll中用malloc给结构体的成员赋值都不会出错。

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

navicat(内含激活码)

navicat支持mysql的可视化操作,内涵激活码,不用再忍受弹框的痛苦。

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

基于STM32的电子时钟设计

时钟功能 还有闹钟功能,温湿度功能,整点报时功能 你值得拥有

学生成绩管理系统(PHP + MYSQL)

做的是数据库课程设计,使用的php + MySQL,本来是黄金搭配也就没啥说的,推荐使用wamp服务器,里面有详细的使用说明,带有界面的啊!呵呵 不行的话,可以给我留言!

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

多功能数字钟.zip

利用数字电子计数知识设计并制作的数字电子钟(含multisim仿真),该数字钟具有显示星期、24小时制时间、闹铃、整点报时、时间校准功能

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

几率大的Redis面试题(含答案)

本文的面试题如下: Redis 持久化机制 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题 热点数据和冷数据是什么 Memcache与Redis的区别都有哪些? 单线程的redis为什么这么快 redis的数据类型,以及每种数据类型的使用场景,Redis 内部结构 redis的过期策略以及内存淘汰机制【~】 Redis 为什么是单线程的,优点 如何解决redis的并发竞争key问题 Red...

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

u-boot-2015.07.tar.bz2

uboot-2015-07最新代码,喜欢的朋友请拿去

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐