当前位置: 首页 > news >正文

2017山亭区建设局网站佛山网站建设 奇锐科技

2017山亭区建设局网站,佛山网站建设 奇锐科技,菏泽建设集团,深圳工业设计展2021如果你曾经使用过Pandas处理表格数据#xff0c;你可能会熟悉导入数据、清洗和转换的过程#xff0c;然后将其用作模型的输入。然而#xff0c;当你需要扩展和将代码投入生产时#xff0c;你的Pandas管道很可能开始崩溃并运行缓慢。在这篇文章中#xff0c;笔者将分享2个技…如果你曾经使用过Pandas处理表格数据你可能会熟悉导入数据、清洗和转换的过程然后将其用作模型的输入。然而当你需要扩展和将代码投入生产时你的Pandas管道很可能开始崩溃并运行缓慢。在这篇文章中笔者将分享2个技巧帮助你让Pandas代码快得离谱提升数据处理效率并避免常见的陷阱。 技巧1矢量化操作 在Pandas中矢量化操作是一种强大的工具它可以用一种更简洁和高效的方式处理整个数据框的列而不是逐行循环。 它是如何工作的 广播是矢量化操作的一个关键要素它允许您直观地操作具有不同形状的对象。 eg1: 具有3个元素的数组a与标量b相乘得到与Source形状相同的数组。 eg2: 在进行加法运算时将形状为(4,1)的数组a与形状为(3,)的数组b相加结果会得到一个形状为(4,3)的数组。 关于这一点已经有很多文章并且在深度学习中大规模的矩阵乘法是非常常见的。在本文中我们将利用两个简短的例子上进行讨论。 首先假设您想要计算给定整数在列中出现的次数。以下是 2 种可能的方法。 计算DataFrame X 中 column_1 列中等于目标值 target 的元素个数。参数 X: DataFrame包含要计算的列 column_1。 target: int目标值。返回值 int等于目标值 target 的元素个数。# 使用循环计数 def count_loop(X, target: int) - int:return sum(x target for x in X[column_1])# 使用矢量化操作计数 def count_vectorized(X, target: int) - int:return (X[column_1] target).sum() 现在假设有一个DataFrame带有日期列并希望将其偏移给定的天数。使用矢量化操作计算如下 def offset_loop(X, days: int) - pd.DataFrame:d pd.Timedelta(daysdays)X[column_const] [x d for x in X[column_10]]return Xdef offset_vectorized(X, days: int) - pd.DataFrame:X[column_const] X[column_10] pd.Timedelta(daysdays)return X 技巧2迭代 「for循环」 第一个也是最直观的迭代方法是使用Python for循环。 def loop(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:res []i_remove_col df.columns.get_loc(remove_col)i_words_to_remove_col df.columns.get_loc(words_to_remove_col)for i_row in range(df.shape[0]):res.append(remove_words(df.iat[i_row, i_remove_col], df.iat[i_row, i_words_to_remove_col]))return result 「apply」 def apply(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:return df.apply(funclambda x: remove_words(x[remove_col], x[words_to_remove_col]), axis1).tolist() 在 df.apply 的每次迭代中提供的可调用函数获取一个 Series其索引为 df.columns其值是行的。这意味着 pandas 必须在每个循环中生成该序列这是昂贵的。为了降低成本最好对您知道将使用的 df 子集调用 apply如下所示 def apply_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:return df[[remove_col, words_to_remove_col]].apply(funclambda x: remove_words(x[remove_col], x[words_to_remove_col]), axis1) 「列表组合itertuples」 使用itertuples与列表相结合进行迭代肯定会更好。itertuples生成带有行数据的命名元组。 def itertuples_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:return [remove_words(x[0], x[1])for x in df[[remove_col, words_to_remove_col]].itertuples(indexFalse, nameNone)] 「列表组合zip」 zip接受可迭代对象并生成元组其中第i个元组按顺序包含所有给定可迭代对象的第i个元素。 def zip_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:return [remove_words(x, y) for x, y in zip(df[remove_col], df[words_to_remove_col])] 「列表组合to_dict」 def to_dict_only_used_columns(df: pd.DataFrame) - list[str]:return [remove_words(row[remove_col], row[words_to_remove_col])for row in df[[remove_col, words_to_remove_col]].to_dict(orientrecords)] 「缓存」 除了我们讨论的迭代技术之外另外两种方法可以帮助提高代码的性能缓存和并行化。如果使用相同的参数多次调用 pandas 函数缓存会特别有用。例如如果remove_words应用于具有许多重复值的数据集您可以使用它functools.lru_cache来存储函数的结果并避免每次都重新计算它们。要使用lru_cache只需将lru_cache装饰器添加到 的声明中remove_words然后使用您首选的迭代方法将该函数应用于您的数据集。这可以显着提高代码的速度和效率。以下面的代码为例 lru_cache def remove_words(...):... # Same implementation as beforedef zip_only_used_cols_cached(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:return [remove_words(x, y) for x, y in zip(df[remove_col], df[words_to_remove_col])] 添加此装饰器会生成一个函数该函数会“记住”之前遇到的输入的输出从而无需再次运行所有代码。 「并行化」 最后一张王牌是使用 pandarallel 跨多个独立的 df 块并行化我们的函数调用。该工具易于使用您只需导入并初始化它然后将所有 .applys 更改为 .parallel_applys。 from pandarallel import pandarallel pandarallel.initialize(nb_workersmin(os.cpu_count(), 12))def parapply_only_used_cols(df: pd.DataFrame, remove_col: str, words_to_remove_col: str) - list[str]:return df[[remove_col, words_to_remove_col]].parallel_apply(lambda x: remove_words(x[remove_col], x[words_to_remove_col]), axis1)
http://www.zqtcl.cn/news/214341/

相关文章:

  • 思勤传媒网站建设公司如何查询网站的外链
  • 网站设计思路文案范文专业手机网站建设多少钱
  • 有部分网站打不开网站服务内容怎么写
  • 百度安全网站检测好看的免费的小说网站模板
  • 锡山区住房和城乡建设局网站免费ppt模板下载简约
  • 建设银行 杭州招聘网站建设工程有限公司是干什么的
  • 做网站必须购买空间吗?3点新闻发布
  • 济南集团网站建设流程东莞做网站公司首选
  • 有需要做网站推广找我网站怎么 备案
  • 怎么把网站放到服务器上站长工具seo综合查询外部链接数量
  • 做网站上市的公司开一家公司最低注册资金
  • 仙居谁认识做网站的有哪些好的网站建设
  • 互动广告机网站建设怀集网站建设
  • 好的 做网站的软件公司pinterest app下载
  • 公司网站报价邯郸软件定制
  • 产品毕业设计代做网站资料库网站源码
  • 交易类网站做支付宝功能建设银行网站收款怎么打明细
  • 广州找人做网站做网站网关备案
  • 网站的布局方式有哪些内容免费ppt模板下载公众号
  • 色91Av做爰网站获胜者网站建设
  • 企业做网站要多少钱简单网页设计模板网站
  • 住宅城乡建设部门户网站seo主管的seo优化方案
  • 商洛做网站电话北京做网站比较大的公司
  • 某俄文网站电脑做网站服务器
  • 广州网站建设开发团队江苏省建设招标网站
  • 南昌建设工程质量监督网站wordpress菜单登录
  • 网站设计贵不贵网站seo设置是什么
  • 不属于企业网站建设基本标准的是南通网站建设知识
  • 玉树州wap网站建设公司做试玩网站
  • 商城网站怎么建保定网络营销网站建设