English

Contextualized Data-Wrangling Code Generation in Computational Notebooks

Software Engineering 2024-09-23 v1 Computation and Language Databases

Abstract

Data wrangling, the process of preparing raw data for further analysis in computational notebooks, is a crucial yet time-consuming step in data science. Code generation has the potential to automate the data wrangling process to reduce analysts' overhead by translating user intents into executable code. Precisely generating data wrangling code necessitates a comprehensive consideration of the rich context present in notebooks, including textual context, code context and data context. However, notebooks often interleave multiple non-linear analysis tasks into linear sequence of code blocks, where the contextual dependencies are not clearly reflected. Directly training models with source code blocks fails to fully exploit the contexts for accurate wrangling code generation. To bridge the gap, we aim to construct a high quality datasets with clear and rich contexts to help training models for data wrangling code generation tasks. In this work, we first propose an automated approach, CoCoMine to mine data-wrangling code generation examples with clear multi-modal contextual dependency. It first adopts data flow analysis to identify the code blocks containing data wrangling codes. Then, CoCoMine extracts the contextualized datawrangling code examples through tracing and replaying notebooks. With CoCoMine, we construct CoCoNote, a dataset containing 58,221 examples for Contextualized Data-wrangling Code generation in Notebooks. To demonstrate the effectiveness of our dataset, we finetune a range of pretrained code models and prompt various large language models on our task. Furthermore, we also propose DataCoder, which encodes data context and code&textual contexts separately to enhance code generation. Experiment results demonstrate the significance of incorporating data context in data-wrangling code generation and the effectiveness of our model. We release code and data at url...

Keywords

Cite

@article{arxiv.2409.13551,
  title  = {Contextualized Data-Wrangling Code Generation in Computational Notebooks},
  author = {Junjie Huang and Daya Guo and Chenglong Wang and Jiazhen Gu and Shuai Lu and Jeevana Priya Inala and Cong Yan and Jianfeng Gao and Nan Duan and Michael R. Lyu},
  journal= {arXiv preprint arXiv:2409.13551},
  year   = {2024}
}

Comments

To appear at ASE 2024